2018-06-23 08:52:45 +02:00
|
|
|
import React, { Component } from 'react'
|
|
|
|
import PropTypes from 'prop-types'
|
|
|
|
import classnames from 'classnames'
|
|
|
|
import { Tabs, Tab } from '../../tabs'
|
2018-09-16 08:50:17 +02:00
|
|
|
import { ConfirmPageContainerSummary, ConfirmPageContainerWarning } from './'
|
|
|
|
import ErrorMessage from '../../error-message'
|
2018-06-23 08:52:45 +02:00
|
|
|
|
|
|
|
export default class ConfirmPageContainerContent extends Component {
|
|
|
|
static propTypes = {
|
|
|
|
action: PropTypes.string,
|
|
|
|
dataComponent: PropTypes.node,
|
2018-07-06 20:58:41 +02:00
|
|
|
detailsComponent: PropTypes.node,
|
|
|
|
errorKey: PropTypes.string,
|
|
|
|
errorMessage: PropTypes.string,
|
|
|
|
hideSubtitle: PropTypes.bool,
|
2018-06-23 08:52:45 +02:00
|
|
|
identiconAddress: PropTypes.string,
|
|
|
|
nonce: PropTypes.string,
|
2018-08-30 04:13:25 +02:00
|
|
|
assetImage: PropTypes.string,
|
2018-07-06 20:58:41 +02:00
|
|
|
subtitle: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
2018-10-17 01:03:29 +02:00
|
|
|
subtitleComponent: PropTypes.node,
|
2018-07-06 20:58:41 +02:00
|
|
|
summaryComponent: PropTypes.node,
|
|
|
|
title: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
2018-10-17 01:03:29 +02:00
|
|
|
titleComponent: PropTypes.node,
|
2018-06-23 08:52:45 +02:00
|
|
|
warning: PropTypes.string,
|
|
|
|
}
|
|
|
|
|
|
|
|
renderContent () {
|
|
|
|
const { detailsComponent, dataComponent } = this.props
|
|
|
|
|
|
|
|
if (detailsComponent && dataComponent) {
|
|
|
|
return this.renderTabs()
|
|
|
|
} else {
|
|
|
|
return detailsComponent || dataComponent
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
renderTabs () {
|
|
|
|
const { detailsComponent, dataComponent } = this.props
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Tabs>
|
|
|
|
<Tab name="Details">
|
|
|
|
{ detailsComponent }
|
|
|
|
</Tab>
|
|
|
|
<Tab name="Data">
|
|
|
|
{ dataComponent }
|
|
|
|
</Tab>
|
|
|
|
</Tabs>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
render () {
|
|
|
|
const {
|
|
|
|
action,
|
2018-07-06 20:58:41 +02:00
|
|
|
errorKey,
|
|
|
|
errorMessage,
|
2018-06-23 08:52:45 +02:00
|
|
|
title,
|
2018-10-17 01:03:29 +02:00
|
|
|
titleComponent,
|
2018-06-23 08:52:45 +02:00
|
|
|
subtitle,
|
2018-10-17 01:03:29 +02:00
|
|
|
subtitleComponent,
|
2018-06-23 08:52:45 +02:00
|
|
|
hideSubtitle,
|
|
|
|
identiconAddress,
|
|
|
|
nonce,
|
2018-08-30 04:13:25 +02:00
|
|
|
assetImage,
|
2018-06-23 08:52:45 +02:00
|
|
|
summaryComponent,
|
|
|
|
detailsComponent,
|
|
|
|
dataComponent,
|
|
|
|
warning,
|
|
|
|
} = this.props
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="confirm-page-container-content">
|
|
|
|
{
|
|
|
|
warning && (
|
|
|
|
<ConfirmPageContainerWarning warning={warning} />
|
|
|
|
)
|
|
|
|
}
|
|
|
|
{
|
|
|
|
summaryComponent || (
|
|
|
|
<ConfirmPageContainerSummary
|
|
|
|
className={classnames({
|
|
|
|
'confirm-page-container-summary--border': !detailsComponent || !dataComponent,
|
|
|
|
})}
|
|
|
|
action={action}
|
|
|
|
title={title}
|
2018-10-17 01:03:29 +02:00
|
|
|
titleComponent={titleComponent}
|
2018-06-23 08:52:45 +02:00
|
|
|
subtitle={subtitle}
|
2018-10-17 01:03:29 +02:00
|
|
|
subtitleComponent={subtitleComponent}
|
2018-06-23 08:52:45 +02:00
|
|
|
hideSubtitle={hideSubtitle}
|
|
|
|
identiconAddress={identiconAddress}
|
|
|
|
nonce={nonce}
|
2018-08-30 04:13:25 +02:00
|
|
|
assetImage={assetImage}
|
2018-06-23 08:52:45 +02:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
{ this.renderContent() }
|
|
|
|
{
|
2018-07-06 20:58:41 +02:00
|
|
|
(errorKey || errorMessage) && (
|
2018-06-23 08:52:45 +02:00
|
|
|
<div className="confirm-page-container-content__error-container">
|
2018-09-16 08:50:17 +02:00
|
|
|
<ErrorMessage
|
2018-07-06 20:58:41 +02:00
|
|
|
errorMessage={errorMessage}
|
|
|
|
errorKey={errorKey}
|
|
|
|
/>
|
2018-06-23 08:52:45 +02:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|