aboutsummaryrefslogblamecommitdiffstats
path: root/ui/app/components/send/currency-display.js
blob: 8b72b3e6dd1cdce8e37263bf6ed72345bf13712b (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11

                                            
                                                  
                                                                               




                                    
 
                              


                                        
                                


                           
 


                                                        

                                                                                  



                      
                                                


                                                                    
                      
                     
                    
          
                 
                
 
                                               




                            
 
                                                        

                                  
                        

                   
                                                
 
                   
              

                                          


                                            
                                                
                          
                                             
                                    
                           
                   
                                                  
            
           
                                                                     
         

       
                                           
                                                               
    
 
 
const Component = require('react').Component
const h = require('react-hyperscript')
const inherits = require('util').inherits
const CurrencyInput = require('../currency-input')
const { conversionUtil, multiplyCurrencies } = require('../../conversion-util')

module.exports = CurrencyDisplay

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

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

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

CurrencyDisplay.prototype.getAmount = function (value) {
  const { selectedToken } = this.props
  const { decimals } = selectedToken || {}
  const multiplier = Math.pow(10, Number(decimals || 0))

  const sendAmount = multiplyCurrencies(value, multiplier, {toNumericBase: 'hex'})

  return selectedToken
    ? sendAmount
    : toHexWei(value)
}

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

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

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

  const inputSizeMultiplier = readOnly ? 1 : 1.2

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

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

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

        h(CurrencyInput, {
          className: primaryBalanceClassName,
          value: `${valueToRender}`,
          placeholder: '0',
          readOnly,
          onInputChange: newValue => {
            handleChange(this.getAmount(newValue))
          },
        }),

        h('span.currency-display__currency-symbol', primaryCurrency),

      ]),

    ]),

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

  ])

}