2018-08-16 04:18:01 +02:00
|
|
|
import React, { PureComponent } from 'react'
|
|
|
|
import PropTypes from 'prop-types'
|
2018-11-20 01:06:34 +01:00
|
|
|
import CurrencyDisplay from '../currency-display'
|
2018-08-16 04:18:01 +02:00
|
|
|
import { getTokenData } from '../../helpers/transactions.util'
|
2018-10-09 02:05:57 +02:00
|
|
|
import { getTokenValue, calcTokenAmount } from '../../token-util'
|
2018-08-16 04:18:01 +02:00
|
|
|
|
2018-08-24 01:44:38 +02:00
|
|
|
export default class TokenCurrencyDisplay extends PureComponent {
|
2018-08-16 04:18:01 +02:00
|
|
|
static propTypes = {
|
|
|
|
transactionData: PropTypes.string,
|
|
|
|
token: PropTypes.object,
|
|
|
|
}
|
|
|
|
|
|
|
|
state = {
|
|
|
|
displayValue: '',
|
2018-11-20 01:06:34 +01:00
|
|
|
suffix: '',
|
2018-08-16 04:18:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount () {
|
|
|
|
this.setDisplayValue()
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidUpdate (prevProps) {
|
|
|
|
const { transactionData } = this.props
|
|
|
|
const { transactionData: prevTransactionData } = prevProps
|
|
|
|
|
|
|
|
if (transactionData !== prevTransactionData) {
|
|
|
|
this.setDisplayValue()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
setDisplayValue () {
|
|
|
|
const { transactionData: data, token } = this.props
|
2018-11-20 01:06:34 +01:00
|
|
|
const { decimals = '', symbol: suffix = '' } = token
|
2018-08-16 04:18:01 +02:00
|
|
|
const tokenData = getTokenData(data)
|
|
|
|
|
|
|
|
let displayValue
|
|
|
|
|
2019-01-04 13:06:25 +01:00
|
|
|
if (tokenData && tokenData.params && tokenData.params.length) {
|
2018-10-09 02:05:57 +02:00
|
|
|
const tokenValue = getTokenValue(tokenData.params)
|
2018-11-20 01:06:34 +01:00
|
|
|
displayValue = calcTokenAmount(tokenValue, decimals).toString()
|
2018-08-16 04:18:01 +02:00
|
|
|
}
|
|
|
|
|
2018-11-20 01:06:34 +01:00
|
|
|
this.setState({ displayValue, suffix })
|
2018-08-16 04:18:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
render () {
|
2018-11-20 01:06:34 +01:00
|
|
|
const { displayValue, suffix } = this.state
|
|
|
|
|
2018-08-16 04:18:01 +02:00
|
|
|
return (
|
|
|
|
<CurrencyDisplay
|
|
|
|
{...this.props}
|
2018-11-20 01:06:34 +01:00
|
|
|
displayValue={displayValue}
|
|
|
|
suffix={suffix}
|
2018-08-16 04:18:01 +02:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|