1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/pages/swaps/view-on-block-explorer/view-on-block-explorer.js

52 lines
1.6 KiB
JavaScript
Raw Normal View History

import React, { useContext } from 'react';
import PropTypes from 'prop-types';
import Box from '../../../components/ui/box';
import { I18nContext } from '../../../contexts/i18n';
import { getURLHostName } from '../../../helpers/utils/util';
import { MetaMetricsContext } from '../../../contexts/metametrics';
import {
MetaMetricsEventCategory,
MetaMetricsEventLinkType,
MetaMetricsEventName,
} from '../../../../shared/constants/metametrics';
export default function ViewOnBlockExplorer({
blockExplorerUrl,
sensitiveTrackingProperties,
}) {
const t = useContext(I18nContext);
const trackEvent = useContext(MetaMetricsContext);
const blockExplorerHostName = getURLHostName(blockExplorerUrl);
return (
<Box marginTop={6} className="view-on-block-explorer">
<button
onClick={() => {
trackEvent({
event: MetaMetricsEventName.ExternalLinkClicked,
category: MetaMetricsEventCategory.Swaps,
sensitiveProperties: sensitiveTrackingProperties,
properties: {
link_type: MetaMetricsEventLinkType.TransactionBlockExplorer,
location: 'Swap Transaction',
url_domain: blockExplorerHostName,
},
});
global.platform.openTab({ url: blockExplorerUrl });
}}
>
{t('viewOnCustomBlockExplorer', [
t('blockExplorerSwapAction'),
blockExplorerHostName,
])}
</button>
</Box>
);
}
ViewOnBlockExplorer.propTypes = {
blockExplorerUrl: PropTypes.string.isRequired,
sensitiveTrackingProperties: PropTypes.object.isRequired,
};