aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components/send/currency-display.js
blob: 2c9a2d33b99a8388868f745ea3575281c641e131 (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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
const Component = require('react').Component
const h = require('react-hyperscript')
const inherits = require('util').inherits
const Identicon = require('../identicon')
const { conversionUtil } = require('../../conversion-util')

module.exports = CurrencyDisplay

inherits(CurrencyDisplay, Component)
function CurrencyDisplay () {
  Component.call(this)

  this.state = {
    value: null,
  }
}

function isValidInput (text) {
  const re = /^([1-9]\d*|0)(\.|\.\d*)?$/
  return re.test(text)
}

function resetCaretIfPastEnd (value, event) {
  const caretPosition = event.target.selectionStart

  if (caretPosition > value.length) {
    event.target.setSelectionRange(value.length, value.length)
  }
}

function toHexWei (value) {
  return conversionUtil(value, {
    fromNumericBase: 'dec',
    toNumericBase: 'hex',
    toDenomination: 'WEI',
  })
}

CurrencyDisplay.prototype.render = function () {
  const {
    className = 'currency-display',
    primaryBalanceClassName = 'currency-display__input',
    convertedBalanceClassName = 'currency-display__converted-value',
    conversionRate,
    primaryCurrency,
    convertedCurrency,
    convertedPrefix = '',
    placeholder = '0',
    readOnly = false,
    inError = false,
    value: initValue,
    handleChange,
    validate,
  } = this.props
  const { value } = this.state

  const initValueToRender = conversionUtil(initValue, {
    fromNumericBase: 'hex',
    toNumericBase: 'dec',
    fromDenomination: 'WEI',
    numberOfDecimals: 6,
    conversionRate,
  })

  const convertedValue = conversionUtil(value || initValueToRender, {
    fromNumericBase: 'dec',
    fromCurrency: primaryCurrency,
    toCurrency: convertedCurrency,
    numberOfDecimals: 2,
    conversionRate,
  })

  return h('div', {
    className,
    style: {
      borderColor: inError ? 'red' : null,
    },
  }, [

    h('div.currency-display__primary-row', [

      h('div.currency-display__input-wrapper', [

        h('input', {
          className: primaryBalanceClassName,
          value: `${value || initValueToRender} ${primaryCurrency}`,
          placeholder: `${0} ${primaryCurrency}`,
          readOnly,
          onChange: (event) => {
            let newValue = event.target.value.split(' ')[0]

            if (newValue === '') {
              this.setState({ value: '0' })
            }
            else if (newValue.match(/^0[1-9]$/)) {
              this.setState({ value: newValue.match(/[1-9]/)[0] })
            }
            else if (newValue && !isValidInput(newValue)) {
              event.preventDefault()
            }
            else {
              this.setState({ value: newValue })
            }
          },
          onBlur: event => !readOnly && handleChange(toHexWei(event.target.value.split(' ')[0])),
          onKeyUp: event => {
            if (!readOnly) {
              validate(toHexWei(value || initValueToRender))
              resetCaretIfPastEnd(value || initValueToRender, event)
            }
          },
          onClick: event => !readOnly && resetCaretIfPastEnd(value || initValueToRender, event),
        }),

      ]),

    ]),

    h('div', {
      className: convertedBalanceClassName,
    }, `${convertedValue} ${convertedCurrency.toUpperCase()}`),

  ])
    
}