const inherits = require('util').inherits const Component = require('react').Component const h = require('react-hyperscript') const connect = require('react-redux').connect const vreme = new (require('vreme')) const explorerLink = require('../../lib/explorer-link') const extension = require('../../../app/scripts/lib/extension') const actions = require('../actions') const addressSummary = require('../util').addressSummary const CopyButton = require('./copyButton') const EtherBalance = require('./eth-balance') module.exports = connect(mapStateToProps)(ShiftListItem) function mapStateToProps (state) { return {} } inherits(ShiftListItem, Component) function ShiftListItem () { Component.call(this) } ShiftListItem.prototype.render = function () { const props = this.props return ( h(`.transaction-list-item.flex-row`, { style:{ paddingTop: '20px', paddingBottom: '20px', justifyContent: 'space-around', alignItems: 'center', }, }, [ h('div', { style: { width:'0px', position: 'relative', bottom: '19px', }, }, [ h('img', { src:'https://info.shapeshift.io/sites/default/files/logo.png', style: { height: '35px', width: '132px', position: 'absolute', clip: 'rect(0px,23px,34px,0px)', }, }), ]), this.renderInfo(), this.renderUtilComponents(), ]) ) } function formatDate (date) { return vreme.format(new Date(date), 'March 16 2014 14:30') } ShiftListItem.prototype.renderUtilComponents = function () { var props = this.props switch (props.response.status) { case 'no_deposits': return h('.flex-row', [ h(CopyButton, { value: this.props.depositAddress }), h('i.fa.fa-qrcode.pointer', { onClick: () => props.dispatch(actions.reshowQrCode(props.depositAddress, props.depositType)), style: { margin: '5px', marginLeft: '23px', marginRight: '12px', fontSize: '20px', color: '#F7861C', }, }), ]) case 'received': return h('.flex-row') case 'complete': return h('.flex-row', [ h(CopyButton, { value: this.props.response.transaction }), h(EtherBalance, { value: `+${props.response.outgoingCoin}`, width: '55px', shorten: true, style: {fontSize: '15px'}, }) ]) case 'failed': return '' default: return '' } } ShiftListItem.prototype.renderInfo = function () { var props = this.props switch (props.response.status) { case 'no_deposits': return h('.flex-column', {style: {width: '200px', overflow: 'hidden'}}, [ h('div', { style: { fontSize: 'x-small', color: '#ABA9AA', width: '100%', }, }, [ `${props.depositType} to ETH via ShapeShift` ]), h('div', `Status: ${props.response.status.replace('_', ' ')}`), h('div', { style: { fontSize: 'x-small', color: '#ABA9AA', width: '100%', }, }, formatDate(props.time)), ]) case 'received': return h('.flex-column', {style: {width: '200px', overflow: 'hidden'}}, [ h('div', { style: { fontSize: 'x-small', color: '#ABA9AA', width: '100%', }, }, [ `${props.depositType} to ETH via ShapeShift` ]), h('div', `Conversion in progress`), h('div', { style: { fontSize: 'x-small', color: '#ABA9AA', width: '100%', }, }, formatDate(props.time)), ]) case 'complete': var url = explorerLink(props.response.transaction, parseInt('1')) return h('.flex-column.pointer', { style: {width: '200px', overflow: 'hidden'}, onClick: () => extension.tabs.create({ url }) }, [ h('div', { style: { fontSize: 'x-small', color: '#ABA9AA', width: '100%', }, }, `ShapeShift`), h('div', props.completeTime), h('div', { style: { fontSize: 'x-small', color: '#ABA9AA', width: '100%', }, }, addressSummary(props.response.transaction)), ]) case 'failed': return h('span.error', ' (Failed)') default: return '' } }