parent
9b1a3fd7f3
commit
752d16f6c0
@ -0,0 +1,177 @@ |
|||||||
|
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 '' |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue