mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
116 lines
3.2 KiB
JavaScript
116 lines
3.2 KiB
JavaScript
import React, { useContext } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { useSelector } from 'react-redux';
|
|
|
|
import { useI18nContext } from '../../../../hooks/useI18nContext';
|
|
import { MetaMetricsContext } from '../../../../contexts/metametrics';
|
|
import {
|
|
MetaMetricsEventCategory,
|
|
MetaMetricsEventName,
|
|
MetaMetricsTokenEventSource,
|
|
} from '../../../../../shared/constants/metametrics';
|
|
import {
|
|
getCurrentChainId,
|
|
getDetectedTokensInCurrentNetwork,
|
|
} from '../../../../selectors';
|
|
|
|
import Popover from '../../../ui/popover';
|
|
import Box from '../../../ui/box';
|
|
import Button from '../../../ui/button';
|
|
import DetectedTokenDetails from '../detected-token-details/detected-token-details';
|
|
|
|
const DetectedTokenSelectionPopover = ({
|
|
tokensListDetected,
|
|
handleTokenSelection,
|
|
onImport,
|
|
onIgnoreAll,
|
|
setShowDetectedTokens,
|
|
sortingBasedOnTokenSelection,
|
|
}) => {
|
|
const t = useI18nContext();
|
|
const trackEvent = useContext(MetaMetricsContext);
|
|
|
|
const chainId = useSelector(getCurrentChainId);
|
|
|
|
const detectedTokens = useSelector(getDetectedTokensInCurrentNetwork);
|
|
const { selected: selectedTokens = [] } =
|
|
sortingBasedOnTokenSelection(tokensListDetected);
|
|
const numOfTokensImporting =
|
|
selectedTokens.length === detectedTokens.length
|
|
? `All`
|
|
: `(${selectedTokens.length})`;
|
|
|
|
const onClose = () => {
|
|
setShowDetectedTokens(false);
|
|
const eventTokensDetails = detectedTokens.map(
|
|
({ address, symbol }) => `${symbol} - ${address}`,
|
|
);
|
|
trackEvent({
|
|
event: MetaMetricsEventName.TokenImportCanceled,
|
|
category: MetaMetricsEventCategory.Wallet,
|
|
properties: {
|
|
source_connection_method: MetaMetricsTokenEventSource.Detected,
|
|
chain_id: chainId,
|
|
tokens: eventTokensDetails,
|
|
},
|
|
});
|
|
};
|
|
|
|
const footer = (
|
|
<>
|
|
<Button
|
|
className="detected-token-selection-popover__ignore-button"
|
|
type="secondary"
|
|
onClick={() => onIgnoreAll()}
|
|
>
|
|
{t('ignoreAll')}
|
|
</Button>
|
|
<Button
|
|
className="detected-token-selection-popover__import-button"
|
|
type="primary"
|
|
onClick={onImport}
|
|
disabled={selectedTokens.length === 0}
|
|
>
|
|
{t('importWithCount', [numOfTokensImporting])}
|
|
</Button>
|
|
</>
|
|
);
|
|
|
|
return (
|
|
<Popover
|
|
className="detected-token-selection-popover"
|
|
title={
|
|
detectedTokens.length === 1
|
|
? t('tokenFoundTitle')
|
|
: t('tokensFoundTitle', [detectedTokens.length])
|
|
}
|
|
onClose={onClose}
|
|
footer={footer}
|
|
>
|
|
<Box margin={3}>
|
|
{detectedTokens.map((token, index) => {
|
|
return (
|
|
<DetectedTokenDetails
|
|
key={index}
|
|
token={token}
|
|
handleTokenSelection={handleTokenSelection}
|
|
tokensListDetected={tokensListDetected}
|
|
/>
|
|
);
|
|
})}
|
|
</Box>
|
|
</Popover>
|
|
);
|
|
};
|
|
|
|
DetectedTokenSelectionPopover.propTypes = {
|
|
tokensListDetected: PropTypes.object,
|
|
handleTokenSelection: PropTypes.func.isRequired,
|
|
onIgnoreAll: PropTypes.func.isRequired,
|
|
onImport: PropTypes.func.isRequired,
|
|
setShowDetectedTokens: PropTypes.func.isRequired,
|
|
sortingBasedOnTokenSelection: PropTypes.func.isRequired,
|
|
};
|
|
|
|
export default DetectedTokenSelectionPopover;
|