aboutsummaryrefslogblamecommitdiffstats
path: root/ui/app/components/sender-to-recipient.js
blob: 420d50e420fc349b7b2e4bb78bdfd19caf2a1537 (plain) (tree)
1
2
3
4
5
6
7

                                      
                                              
                                       


                                           















                                                                           
                                                      




          






















                                                                                       
                               







                                  
                                   

                                     

 


                                                 
const { Component } = require('react')
const h = require('react-hyperscript')
const connect = require('../metamask-connect')
const PropTypes = require('prop-types')
const Identicon = require('./identicon')

class SenderToRecipient extends Component {
  renderRecipientIcon () {
    const { recipientAddress } = this.props
    return (
      recipientAddress
        ? h(Identicon, { address: recipientAddress, diameter: 20 })
        : h('i.fa.fa-file-text-o')
    )
  }

  renderRecipient () {
    const { recipientName } = this.props
    return (
      h('.sender-to-recipient__recipient', [
        this.renderRecipientIcon(),
        h(
          '.sender-to-recipient__name.sender-to-recipient__recipient-name',
          recipientName || this.props.t('newContract')
        ),
      ])
    )
  }

  render () {
    const { senderName, senderAddress } = this.props

    return (
      h('.sender-to-recipient__container', [
        h('.sender-to-recipient__sender', [
          h('.sender-to-recipient__sender-icon', [
            h(Identicon, {
              address: senderAddress,
              diameter: 20,
            }),
          ]),
          h('.sender-to-recipient__name.sender-to-recipient__sender-name', senderName),
        ]),
        h('.sender-to-recipient__arrow-container', [
          h('.sender-to-recipient__arrow-circle', [
            h('img', {
              height: 15,
              width: 15,
              src: '/images/arrow-right.svg',
            }),
          ]),
        ]),
        this.renderRecipient(),
      ])
    )
  }
}

SenderToRecipient.propTypes = {
  senderName: PropTypes.string,
  senderAddress: PropTypes.string,
  localeMessages: PropTypes.object,
  recipientName: PropTypes.string,
  recipientAddress: PropTypes.string,
}

module.exports = {
  AccountDropdowns: connect()(SenderToRecipient),
}