aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components/fiat-value.js
blob: 0aa7d0bc5dcef8fd7f6a79d31a005d40acbc6e17 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
const Component = require('react').Component
const h = require('react-hyperscript')
const inherits = require('util').inherits
const connect = require('react-redux').connect
const formatBalance = require('../util').formatBalance
const generateBalanceObject = require('../util').generateBalanceObject
const Tooltip = require('./tooltip.js')

module.exports = connect(mapStateToProps)(FiatValue)

function mapStateToProps (state) {
  return {
    conversionRate: state.metamask.conversionRate,
    currentFiat: state.metamask.currentFiat,
  }
}

inherits(FiatValue, Component)
function FiatValue () {
  Component.call(this)
}

FiatValue.prototype.render = function () {
  const props = this.props
  const value = formatBalance(props.value, 6)

  if (value === 'None') return value
  var balanceObj = generateBalanceObject(value, props.shorten ? 1 : 3)
  var fiatDisplayNumber, fiatTooltipNumber
  var splitBalance = value.split(' ')

  if (props.conversionRate !== 0) {
    fiatTooltipNumber = Number(splitBalance[0]) * props.conversionRate
    fiatDisplayNumber = fiatTooltipNumber.toFixed(2)
  } else {
    fiatDisplayNumber = 'N/A'
  }

  var fiatSuffix = props.currentFiat

  return (
    h(Tooltip, {
      position: 'bottom',
      title: `${fiatTooltipNumber} ${fiatSuffix}`,
    }, [
      fiatDisplay(fiatDisplayNumber, fiatSuffix),
    ])
  )
}

function fiatDisplay (fiatDisplayNumber, fiatSuffix) {
  if (fiatDisplayNumber !== 'N/A') {
    return h('.flex-row', {
      style: {
        alignItems: 'flex-end',
        lineHeight: '13px',
        fontFamily: 'Montserrat Light',
        textRendering: 'geometricPrecision',
      },
    }, [
      h('div', {
        style: {
          width: '100%',
          textAlign: 'right',
          fontSize: '12px',
          color: '#333333',
        },
      }, fiatDisplayNumber),
      h('div', {
        style: {
          color: '#AEAEAE',
          marginLeft: '5px',
          fontSize: '12px',
        },
      }, fiatSuffix),
    ])
  } else {
    return h('div')
  }
}