2021-02-04 19:15:23 +01:00
|
|
|
import React, { Component } from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
import { Tabs, Tab } from '../../../ui/tabs';
|
2022-02-23 16:03:01 +01:00
|
|
|
import Button from '../../../ui/button';
|
2021-11-22 13:13:30 +01:00
|
|
|
import ActionableMessage from '../../../ui/actionable-message/actionable-message';
|
2021-02-04 19:15:23 +01:00
|
|
|
import { PageContainerFooter } from '../../../ui/page-container';
|
2022-02-23 16:03:01 +01:00
|
|
|
import ErrorMessage from '../../../ui/error-message';
|
|
|
|
import { INSUFFICIENT_FUNDS_ERROR_KEY } from '../../../../helpers/constants/error-keys';
|
|
|
|
import Typography from '../../../ui/typography';
|
2023-02-02 21:15:26 +01:00
|
|
|
import { TypographyVariant } from '../../../../helpers/constants/design-system';
|
2022-02-23 16:03:01 +01:00
|
|
|
|
2023-02-23 12:38:09 +01:00
|
|
|
import SecurityProviderBannerMessage from '../../security-provider-banner-message/security-provider-banner-message';
|
|
|
|
import { SECURITY_PROVIDER_MESSAGE_SEVERITIES } from '../../security-provider-banner-message/security-provider-banner-message.constants';
|
2021-02-04 19:15:23 +01:00
|
|
|
import { ConfirmPageContainerSummary, ConfirmPageContainerWarning } from '.';
|
2020-08-18 16:10:56 +02:00
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
export default class ConfirmPageContainerContent extends Component {
|
2021-06-13 00:25:24 +02:00
|
|
|
static contextTypes = {
|
|
|
|
t: PropTypes.func.isRequired,
|
|
|
|
};
|
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
static propTypes = {
|
|
|
|
action: PropTypes.string,
|
|
|
|
dataComponent: PropTypes.node,
|
2021-12-01 18:22:08 +01:00
|
|
|
dataHexComponent: PropTypes.node,
|
2018-07-06 20:58:41 +02:00
|
|
|
detailsComponent: PropTypes.node,
|
2023-04-25 16:32:51 +02:00
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(snaps)
|
2022-09-20 19:00:07 +02:00
|
|
|
insightComponent: PropTypes.node,
|
|
|
|
///: END:ONLY_INCLUDE_IN
|
2018-07-06 20:58:41 +02:00
|
|
|
errorKey: PropTypes.string,
|
|
|
|
errorMessage: PropTypes.string,
|
2022-03-03 20:56:20 +01:00
|
|
|
tokenAddress: PropTypes.string,
|
2018-06-23 08:52:45 +02:00
|
|
|
nonce: PropTypes.string,
|
2018-10-17 01:03:29 +02:00
|
|
|
subtitleComponent: PropTypes.node,
|
2022-01-10 17:23:53 +01:00
|
|
|
image: PropTypes.string,
|
2018-10-17 01:03:29 +02:00
|
|
|
titleComponent: PropTypes.node,
|
2018-06-23 08:52:45 +02:00
|
|
|
warning: PropTypes.string,
|
2021-01-28 18:59:45 +01:00
|
|
|
origin: PropTypes.string.isRequired,
|
2021-04-28 20:02:01 +02:00
|
|
|
ethGasPriceWarning: PropTypes.string,
|
2020-08-18 16:10:56 +02:00
|
|
|
// Footer
|
|
|
|
onCancelAll: PropTypes.func,
|
|
|
|
onCancel: PropTypes.func,
|
|
|
|
cancelText: PropTypes.string,
|
|
|
|
onSubmit: PropTypes.func,
|
|
|
|
submitText: PropTypes.string,
|
|
|
|
disabled: PropTypes.bool,
|
|
|
|
unapprovedTxCount: PropTypes.number,
|
|
|
|
rejectNText: PropTypes.string,
|
2022-12-08 19:37:06 +01:00
|
|
|
supportsEIP1559: PropTypes.bool,
|
2022-01-15 04:12:20 +01:00
|
|
|
hasTopBorder: PropTypes.bool,
|
2022-02-23 16:03:01 +01:00
|
|
|
nativeCurrency: PropTypes.string,
|
|
|
|
networkName: PropTypes.string,
|
2022-03-02 16:26:53 +01:00
|
|
|
toAddress: PropTypes.string,
|
|
|
|
transactionType: PropTypes.string,
|
2022-03-25 15:02:08 +01:00
|
|
|
isBuyableChain: PropTypes.bool,
|
2023-02-23 12:38:09 +01:00
|
|
|
txData: PropTypes.object,
|
2021-02-04 19:15:23 +01:00
|
|
|
};
|
2018-06-23 08:52:45 +02:00
|
|
|
|
2020-11-03 00:41:28 +01:00
|
|
|
renderContent() {
|
2021-02-04 19:15:23 +01:00
|
|
|
const { detailsComponent, dataComponent } = this.props;
|
2018-06-23 08:52:45 +02:00
|
|
|
|
2023-04-25 16:32:51 +02:00
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(snaps)
|
2022-09-20 19:00:07 +02:00
|
|
|
const { insightComponent } = this.props;
|
|
|
|
|
|
|
|
if (insightComponent && (detailsComponent || dataComponent)) {
|
|
|
|
return this.renderTabs();
|
|
|
|
}
|
|
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
if (detailsComponent && dataComponent) {
|
2021-02-04 19:15:23 +01:00
|
|
|
return this.renderTabs();
|
2018-06-23 08:52:45 +02:00
|
|
|
}
|
2022-09-20 19:00:07 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
detailsComponent ||
|
2023-04-25 16:32:51 +02:00
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(snaps)
|
2022-09-20 19:00:07 +02:00
|
|
|
insightComponent ||
|
|
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
dataComponent
|
|
|
|
);
|
2018-06-23 08:52:45 +02:00
|
|
|
}
|
|
|
|
|
2020-11-03 00:41:28 +01:00
|
|
|
renderTabs() {
|
2021-06-13 00:25:24 +02:00
|
|
|
const { t } = this.context;
|
2022-09-20 19:00:07 +02:00
|
|
|
const {
|
|
|
|
detailsComponent,
|
|
|
|
dataComponent,
|
|
|
|
dataHexComponent,
|
2023-04-25 16:32:51 +02:00
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(snaps)
|
2022-09-20 19:00:07 +02:00
|
|
|
insightComponent,
|
|
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
} = this.props;
|
2018-06-23 08:52:45 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
<Tabs>
|
2021-06-13 00:25:24 +02:00
|
|
|
<Tab
|
|
|
|
className="confirm-page-container-content__tab"
|
|
|
|
name={t('details')}
|
2023-01-19 16:05:42 +01:00
|
|
|
tabKey="details"
|
2021-06-13 00:25:24 +02:00
|
|
|
>
|
2020-11-03 00:41:28 +01:00
|
|
|
{detailsComponent}
|
2018-06-23 08:52:45 +02:00
|
|
|
</Tab>
|
2022-10-26 11:09:32 +02:00
|
|
|
{dataComponent && (
|
2023-01-19 16:05:42 +01:00
|
|
|
<Tab
|
|
|
|
className="confirm-page-container-content__tab"
|
|
|
|
name={t('data')}
|
|
|
|
tabKey="data"
|
|
|
|
>
|
2022-10-26 11:09:32 +02:00
|
|
|
{dataComponent}
|
|
|
|
</Tab>
|
|
|
|
)}
|
2021-12-07 16:12:34 +01:00
|
|
|
{dataHexComponent && (
|
|
|
|
<Tab
|
|
|
|
className="confirm-page-container-content__tab"
|
|
|
|
name={t('dataHex')}
|
2023-01-19 16:05:42 +01:00
|
|
|
tabKey="dataHex"
|
2021-12-07 16:12:34 +01:00
|
|
|
>
|
|
|
|
{dataHexComponent}
|
|
|
|
</Tab>
|
|
|
|
)}
|
2022-09-20 19:00:07 +02:00
|
|
|
|
|
|
|
{
|
2023-04-25 16:32:51 +02:00
|
|
|
///: BEGIN:ONLY_INCLUDE_IN(snaps)
|
2022-09-20 19:00:07 +02:00
|
|
|
insightComponent
|
|
|
|
///: END:ONLY_INCLUDE_IN
|
|
|
|
}
|
2018-06-23 08:52:45 +02:00
|
|
|
</Tabs>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2018-06-23 08:52:45 +02:00
|
|
|
}
|
|
|
|
|
2020-11-03 00:41:28 +01:00
|
|
|
render() {
|
2018-06-23 08:52:45 +02:00
|
|
|
const {
|
|
|
|
action,
|
2018-07-06 20:58:41 +02:00
|
|
|
errorKey,
|
|
|
|
errorMessage,
|
2022-01-10 17:23:53 +01:00
|
|
|
image,
|
2018-10-17 01:03:29 +02:00
|
|
|
titleComponent,
|
|
|
|
subtitleComponent,
|
2022-03-03 20:56:20 +01:00
|
|
|
tokenAddress,
|
2018-06-23 08:52:45 +02:00
|
|
|
nonce,
|
|
|
|
detailsComponent,
|
|
|
|
dataComponent,
|
|
|
|
warning,
|
2020-08-18 16:10:56 +02:00
|
|
|
onCancelAll,
|
|
|
|
onCancel,
|
|
|
|
cancelText,
|
|
|
|
onSubmit,
|
|
|
|
submitText,
|
|
|
|
disabled,
|
|
|
|
unapprovedTxCount,
|
|
|
|
rejectNText,
|
2021-01-28 18:59:45 +01:00
|
|
|
origin,
|
2021-04-28 20:02:01 +02:00
|
|
|
ethGasPriceWarning,
|
2022-12-08 19:37:06 +01:00
|
|
|
supportsEIP1559,
|
2022-01-15 04:12:20 +01:00
|
|
|
hasTopBorder,
|
2022-02-23 16:03:01 +01:00
|
|
|
nativeCurrency,
|
|
|
|
networkName,
|
2022-03-02 16:26:53 +01:00
|
|
|
toAddress,
|
|
|
|
transactionType,
|
2022-03-25 15:02:08 +01:00
|
|
|
isBuyableChain,
|
2023-02-23 12:38:09 +01:00
|
|
|
txData,
|
2021-02-04 19:15:23 +01:00
|
|
|
} = this.props;
|
2018-06-23 08:52:45 +02:00
|
|
|
|
2022-02-23 16:03:01 +01:00
|
|
|
const { t } = this.context;
|
|
|
|
|
|
|
|
const showInsuffienctFundsError =
|
2022-12-08 19:37:06 +01:00
|
|
|
supportsEIP1559 &&
|
2022-02-23 16:03:01 +01:00
|
|
|
(errorKey || errorMessage) &&
|
2022-03-18 17:06:35 +01:00
|
|
|
errorKey === INSUFFICIENT_FUNDS_ERROR_KEY;
|
2021-11-22 13:13:30 +01:00
|
|
|
|
2018-06-23 08:52:45 +02:00
|
|
|
return (
|
2022-01-15 04:12:20 +01:00
|
|
|
<div
|
|
|
|
className={classnames('confirm-page-container-content', {
|
|
|
|
'confirm-page-container-content--with-top-border': hasTopBorder,
|
|
|
|
})}
|
|
|
|
>
|
2021-10-21 18:11:31 +02:00
|
|
|
{warning ? <ConfirmPageContainerWarning warning={warning} /> : null}
|
2021-04-28 20:02:01 +02:00
|
|
|
{ethGasPriceWarning && (
|
|
|
|
<ConfirmPageContainerWarning warning={ethGasPriceWarning} />
|
|
|
|
)}
|
2023-02-23 12:38:09 +01:00
|
|
|
{(txData?.securityProviderResponse?.flagAsDangerous !== undefined &&
|
|
|
|
txData?.securityProviderResponse?.flagAsDangerous !==
|
|
|
|
SECURITY_PROVIDER_MESSAGE_SEVERITIES.NOT_MALICIOUS) ||
|
|
|
|
(txData?.securityProviderResponse &&
|
|
|
|
Object.keys(txData.securityProviderResponse).length === 0) ? (
|
|
|
|
<SecurityProviderBannerMessage
|
|
|
|
securityProviderResponse={txData.securityProviderResponse}
|
|
|
|
/>
|
|
|
|
) : null}
|
2021-01-28 18:17:26 +01:00
|
|
|
<ConfirmPageContainerSummary
|
|
|
|
className={classnames({
|
|
|
|
'confirm-page-container-summary--border':
|
|
|
|
!detailsComponent || !dataComponent,
|
|
|
|
})}
|
|
|
|
action={action}
|
2022-01-10 17:23:53 +01:00
|
|
|
image={image}
|
2021-01-28 18:17:26 +01:00
|
|
|
titleComponent={titleComponent}
|
|
|
|
subtitleComponent={subtitleComponent}
|
2022-03-03 20:56:20 +01:00
|
|
|
tokenAddress={tokenAddress}
|
2021-01-28 18:17:26 +01:00
|
|
|
nonce={nonce}
|
2021-01-28 18:59:45 +01:00
|
|
|
origin={origin}
|
2022-03-02 16:26:53 +01:00
|
|
|
toAddress={toAddress}
|
|
|
|
transactionType={transactionType}
|
2021-01-28 18:17:26 +01:00
|
|
|
/>
|
2020-11-03 00:41:28 +01:00
|
|
|
{this.renderContent()}
|
2022-12-08 19:37:06 +01:00
|
|
|
{!supportsEIP1559 && (errorKey || errorMessage) && (
|
2022-11-09 16:36:21 +01:00
|
|
|
<div className="confirm-page-container-content__error-container">
|
|
|
|
<ErrorMessage errorMessage={errorMessage} errorKey={errorKey} />
|
|
|
|
</div>
|
|
|
|
)}
|
2022-02-23 16:03:01 +01:00
|
|
|
{showInsuffienctFundsError && (
|
|
|
|
<div className="confirm-page-container-content__error-container">
|
2022-03-25 15:02:08 +01:00
|
|
|
<ActionableMessage
|
|
|
|
className="actionable-message--warning"
|
|
|
|
message={
|
|
|
|
isBuyableChain ? (
|
2023-02-02 21:15:26 +01:00
|
|
|
<Typography variant={TypographyVariant.H7} align="left">
|
2022-03-25 15:02:08 +01:00
|
|
|
{t('insufficientCurrencyBuyOrDeposit', [
|
|
|
|
nativeCurrency,
|
|
|
|
networkName,
|
|
|
|
<Button
|
|
|
|
type="inline"
|
|
|
|
className="confirm-page-container-content__link"
|
2023-03-01 09:45:27 +01:00
|
|
|
onClick={() => {
|
|
|
|
const portfolioUrl = process.env.PORTFOLIO_URL;
|
|
|
|
global.platform.openTab({
|
|
|
|
url: `${portfolioUrl}/buy?metamaskEntry=ext_buy_button`,
|
|
|
|
});
|
|
|
|
}}
|
2022-03-25 15:02:08 +01:00
|
|
|
key={`${nativeCurrency}-buy-button`}
|
|
|
|
>
|
|
|
|
{t('buyAsset', [nativeCurrency])}
|
|
|
|
</Button>,
|
|
|
|
])}
|
2022-02-23 16:03:01 +01:00
|
|
|
</Typography>
|
2022-03-25 15:02:08 +01:00
|
|
|
) : (
|
2023-02-02 21:15:26 +01:00
|
|
|
<Typography variant={TypographyVariant.H7} align="left">
|
2022-03-25 15:02:08 +01:00
|
|
|
{t('insufficientCurrencyDeposit', [
|
|
|
|
nativeCurrency,
|
|
|
|
networkName,
|
|
|
|
])}
|
2022-02-23 16:03:01 +01:00
|
|
|
</Typography>
|
2022-03-25 15:02:08 +01:00
|
|
|
)
|
|
|
|
}
|
|
|
|
useIcon
|
|
|
|
iconFillColor="var(--color-error-default)"
|
|
|
|
type="danger"
|
|
|
|
/>
|
2022-02-23 16:03:01 +01:00
|
|
|
</div>
|
|
|
|
)}
|
2020-08-18 16:10:56 +02:00
|
|
|
<PageContainerFooter
|
|
|
|
onCancel={onCancel}
|
|
|
|
cancelText={cancelText}
|
|
|
|
onSubmit={onSubmit}
|
|
|
|
submitText={submitText}
|
|
|
|
disabled={disabled}
|
|
|
|
>
|
2021-10-21 18:11:31 +02:00
|
|
|
{unapprovedTxCount > 1 ? (
|
|
|
|
<a onClick={onCancelAll}>{rejectNText}</a>
|
|
|
|
) : null}
|
2020-08-18 16:10:56 +02:00
|
|
|
</PageContainerFooter>
|
2018-06-23 08:52:45 +02:00
|
|
|
</div>
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
2018-06-23 08:52:45 +02:00
|
|
|
}
|
|
|
|
}
|