mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
1304ec7af5
We want to convert NetworkController to TypeScript in order to be able to compare differences in the controller between in this repo and the core repo. To do this, however, we need to convert the dependencies of the controller to TypeScript. As a part of this effort, this commit converts `shared/constants/metametrics` to TypeScript. Note that simple objects have been largely replaced with enums. There are some cases where I even split up some of these objects into multiple enums. Co-authored-by: Mark Stacey <markjstacey@gmail.com>
165 lines
5.5 KiB
JavaScript
165 lines
5.5 KiB
JavaScript
import React, { useContext, useEffect } from 'react';
|
|
import { shallowEqual, useDispatch, useSelector } from 'react-redux';
|
|
import { useHistory } from 'react-router-dom';
|
|
import isEqual from 'lodash/isEqual';
|
|
|
|
import { I18nContext } from '../../../contexts/i18n';
|
|
import {
|
|
getFetchParams,
|
|
getApproveTxParams,
|
|
prepareToLeaveSwaps,
|
|
getSmartTransactionsOptInStatus,
|
|
getSmartTransactionsEnabled,
|
|
getCurrentSmartTransactionsEnabled,
|
|
} from '../../../ducks/swaps/swaps';
|
|
import {
|
|
isHardwareWallet,
|
|
getHardwareWalletType,
|
|
} from '../../../selectors/selectors';
|
|
import {
|
|
DEFAULT_ROUTE,
|
|
BUILD_QUOTE_ROUTE,
|
|
} from '../../../helpers/constants/routes';
|
|
import PulseLoader from '../../../components/ui/pulse-loader';
|
|
import Typography from '../../../components/ui/typography';
|
|
import Box from '../../../components/ui/box';
|
|
import {
|
|
BLOCK_SIZES,
|
|
TypographyVariant,
|
|
FONT_WEIGHT,
|
|
JustifyContent,
|
|
DISPLAY,
|
|
TextColor,
|
|
} from '../../../helpers/constants/design-system';
|
|
import SwapsFooter from '../swaps-footer';
|
|
import { MetaMetricsContext } from '../../../contexts/metametrics';
|
|
import { MetaMetricsEventCategory } from '../../../../shared/constants/metametrics';
|
|
import SwapStepIcon from './swap-step-icon';
|
|
|
|
export default function AwaitingSignatures() {
|
|
const t = useContext(I18nContext);
|
|
const history = useHistory();
|
|
const dispatch = useDispatch();
|
|
const fetchParams = useSelector(getFetchParams, isEqual);
|
|
const { destinationTokenInfo, sourceTokenInfo } = fetchParams?.metaData || {};
|
|
const approveTxParams = useSelector(getApproveTxParams, shallowEqual);
|
|
const hardwareWalletUsed = useSelector(isHardwareWallet);
|
|
const hardwareWalletType = useSelector(getHardwareWalletType);
|
|
const smartTransactionsOptInStatus = useSelector(
|
|
getSmartTransactionsOptInStatus,
|
|
);
|
|
const smartTransactionsEnabled = useSelector(getSmartTransactionsEnabled);
|
|
const currentSmartTransactionsEnabled = useSelector(
|
|
getCurrentSmartTransactionsEnabled,
|
|
);
|
|
const needsTwoConfirmations = Boolean(approveTxParams);
|
|
const trackEvent = useContext(MetaMetricsContext);
|
|
|
|
useEffect(() => {
|
|
trackEvent({
|
|
event: 'Awaiting Signature(s) on a HW wallet',
|
|
category: MetaMetricsEventCategory.Swaps,
|
|
sensitiveProperties: {
|
|
needs_two_confirmations: needsTwoConfirmations,
|
|
token_from: sourceTokenInfo?.symbol,
|
|
token_from_amount: fetchParams?.value,
|
|
token_to: destinationTokenInfo?.symbol,
|
|
request_type: fetchParams?.balanceError ? 'Quote' : 'Order',
|
|
slippage: fetchParams?.slippage,
|
|
custom_slippage: fetchParams?.slippage === 2,
|
|
is_hardware_wallet: hardwareWalletUsed,
|
|
hardware_wallet_type: hardwareWalletType,
|
|
stx_enabled: smartTransactionsEnabled,
|
|
current_stx_enabled: currentSmartTransactionsEnabled,
|
|
stx_user_opt_in: smartTransactionsOptInStatus,
|
|
},
|
|
});
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, []);
|
|
|
|
const headerText = needsTwoConfirmations
|
|
? t('swapTwoTransactions')
|
|
: t('swapConfirmWithHwWallet');
|
|
|
|
return (
|
|
<div className="awaiting-signatures">
|
|
<Box
|
|
paddingLeft={8}
|
|
paddingRight={8}
|
|
height={BLOCK_SIZES.FULL}
|
|
justifyContent={JustifyContent.center}
|
|
display={DISPLAY.FLEX}
|
|
className="awaiting-signatures__content"
|
|
>
|
|
<Box marginTop={3} marginBottom={4}>
|
|
<PulseLoader />
|
|
</Box>
|
|
<Typography
|
|
color={TextColor.textDefault}
|
|
variant={TypographyVariant.H3}
|
|
>
|
|
{headerText}
|
|
</Typography>
|
|
{needsTwoConfirmations && (
|
|
<>
|
|
<Typography
|
|
variant={TypographyVariant.paragraph}
|
|
boxProps={{ marginTop: 2 }}
|
|
fontWeight={FONT_WEIGHT.BOLD}
|
|
>
|
|
{t('swapToConfirmWithHwWallet')}
|
|
</Typography>
|
|
<ul className="awaiting-signatures__steps">
|
|
<li>
|
|
<SwapStepIcon stepNumber={1} />
|
|
{t('swapAllowSwappingOf', [
|
|
<Typography
|
|
as="span"
|
|
fontWeight={FONT_WEIGHT.BOLD}
|
|
key="allowToken"
|
|
>
|
|
{destinationTokenInfo?.symbol}
|
|
</Typography>,
|
|
])}
|
|
</li>
|
|
<li>
|
|
<SwapStepIcon stepNumber={2} />
|
|
{t('swapFromTo', [
|
|
<Typography
|
|
as="span"
|
|
fontWeight={FONT_WEIGHT.BOLD}
|
|
key="tokenFrom"
|
|
>
|
|
{sourceTokenInfo?.symbol}
|
|
</Typography>,
|
|
<Typography
|
|
as="span"
|
|
fontWeight={FONT_WEIGHT.BOLD}
|
|
key="tokenTo"
|
|
>
|
|
{destinationTokenInfo?.symbol}
|
|
</Typography>,
|
|
])}
|
|
</li>
|
|
</ul>
|
|
<Typography variant={TypographyVariant.paragraph}>
|
|
{t('swapGasFeesSplit')}
|
|
</Typography>
|
|
</>
|
|
)}
|
|
</Box>
|
|
<SwapsFooter
|
|
onSubmit={async () => {
|
|
await dispatch(prepareToLeaveSwaps());
|
|
// Go to the default route and then to the build quote route in order to clean up
|
|
// the `inputValue` local state in `pages/swaps/index.js`
|
|
history.push(DEFAULT_ROUTE);
|
|
history.push(BUILD_QUOTE_ROUTE);
|
|
}}
|
|
submitText={t('cancel')}
|
|
hideCancel
|
|
/>
|
|
</div>
|
|
);
|
|
}
|