2021-02-22 17:20:42 +01:00
|
|
|
import { ethErrors } from 'eth-rpc-errors';
|
2021-05-26 18:17:18 +02:00
|
|
|
import {
|
|
|
|
CHAIN_ID_TO_TYPE_MAP,
|
|
|
|
NETWORK_TYPE_RPC,
|
|
|
|
} from '../../../../shared/constants/network';
|
2021-02-22 17:20:42 +01:00
|
|
|
import {
|
|
|
|
JUSTIFY_CONTENT,
|
|
|
|
SEVERITIES,
|
|
|
|
TYPOGRAPHY,
|
|
|
|
} from '../../../helpers/constants/design-system';
|
|
|
|
|
|
|
|
const PENDING_TX_DROP_NOTICE = {
|
|
|
|
id: 'PENDING_TX_DROP_NOTICE',
|
|
|
|
severity: SEVERITIES.WARNING,
|
|
|
|
content: {
|
|
|
|
element: 'span',
|
|
|
|
children: {
|
|
|
|
element: 'MetaMaskTranslation',
|
|
|
|
props: {
|
|
|
|
translationKey: 'switchingNetworksCancelsPendingConfirmations',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
async function getAlerts() {
|
|
|
|
return [PENDING_TX_DROP_NOTICE];
|
|
|
|
}
|
|
|
|
|
2021-05-26 18:17:18 +02:00
|
|
|
function getNetworkType(chainId) {
|
|
|
|
if (chainId in CHAIN_ID_TO_TYPE_MAP) {
|
|
|
|
return CHAIN_ID_TO_TYPE_MAP[chainId];
|
|
|
|
}
|
|
|
|
|
|
|
|
return NETWORK_TYPE_RPC;
|
|
|
|
}
|
|
|
|
|
2021-02-22 17:20:42 +01:00
|
|
|
function getValues(pendingApproval, t, actions) {
|
|
|
|
return {
|
|
|
|
content: [
|
|
|
|
{
|
|
|
|
element: 'Typography',
|
|
|
|
key: 'title',
|
|
|
|
children: t('switchEthereumChainConfirmationTitle'),
|
|
|
|
props: {
|
|
|
|
variant: TYPOGRAPHY.H3,
|
|
|
|
align: 'center',
|
|
|
|
fontWeight: 'bold',
|
|
|
|
boxProps: {
|
|
|
|
margin: [0, 0, 4],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
element: 'Typography',
|
|
|
|
key: 'description',
|
|
|
|
children: t('switchEthereumChainConfirmationDescription'),
|
|
|
|
props: {
|
|
|
|
variant: TYPOGRAPHY.H7,
|
|
|
|
align: 'center',
|
|
|
|
boxProps: {
|
|
|
|
margin: [0, 0, 4],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
element: 'Box',
|
|
|
|
key: 'status-box',
|
|
|
|
props: {
|
|
|
|
justifyContent: JUSTIFY_CONTENT.CENTER,
|
|
|
|
},
|
|
|
|
children: {
|
|
|
|
element: 'NetworkDisplay',
|
|
|
|
key: 'network-being-switched',
|
|
|
|
props: {
|
|
|
|
colored: false,
|
|
|
|
outline: true,
|
|
|
|
targetNetwork: {
|
2021-05-26 18:17:18 +02:00
|
|
|
type: getNetworkType(pendingApproval.requestData.chainId),
|
2021-02-22 17:20:42 +01:00
|
|
|
nickname: pendingApproval.requestData.nickname,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
approvalText: t('switchNetwork'),
|
|
|
|
cancelText: t('cancel'),
|
|
|
|
onApprove: () =>
|
|
|
|
actions.resolvePendingApproval(
|
|
|
|
pendingApproval.id,
|
|
|
|
pendingApproval.requestData,
|
|
|
|
),
|
|
|
|
|
|
|
|
onCancel: () =>
|
|
|
|
actions.rejectPendingApproval(
|
|
|
|
pendingApproval.id,
|
|
|
|
ethErrors.provider.userRejectedRequest(),
|
|
|
|
),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
const switchEthereumChain = {
|
|
|
|
getAlerts,
|
|
|
|
getValues,
|
|
|
|
};
|
|
|
|
|
|
|
|
export default switchEthereumChain;
|