2016-08-10 22:43:01 +02:00
|
|
|
const Component = require('react').Component
|
2018-03-29 17:00:44 +02:00
|
|
|
const PropTypes = require('prop-types')
|
2016-08-10 22:43:01 +02:00
|
|
|
const h = require('react-hyperscript')
|
|
|
|
const inherits = require('util').inherits
|
2018-03-29 17:00:44 +02:00
|
|
|
const connect = require('react-redux').connect
|
2016-08-10 22:43:01 +02:00
|
|
|
const actions = require('../actions')
|
|
|
|
const CoinbaseForm = require('./coinbase-form')
|
|
|
|
const ShapeshiftForm = require('./shapeshift-form')
|
2018-05-14 15:30:50 +02:00
|
|
|
const Loading = require('./loading-screen')
|
2017-04-18 18:21:24 +02:00
|
|
|
const AccountPanel = require('./account-panel')
|
|
|
|
const RadioList = require('./custom-radio-list')
|
2018-04-12 23:17:36 +02:00
|
|
|
const { getNetworkDisplayName } = require('../../../app/scripts/controllers/network/util')
|
2016-08-10 22:43:01 +02:00
|
|
|
|
2018-03-29 17:00:44 +02:00
|
|
|
BuyButtonSubview.contextTypes = {
|
|
|
|
t: PropTypes.func,
|
|
|
|
}
|
|
|
|
|
2016-08-10 22:43:01 +02:00
|
|
|
module.exports = connect(mapStateToProps)(BuyButtonSubview)
|
|
|
|
|
2018-03-29 17:00:44 +02:00
|
|
|
|
2016-08-10 22:43:01 +02:00
|
|
|
function mapStateToProps (state) {
|
|
|
|
return {
|
2017-04-18 18:21:24 +02:00
|
|
|
identity: state.appState.identity,
|
|
|
|
account: state.metamask.accounts[state.appState.buyView.buyAddress],
|
2016-08-10 22:43:01 +02:00
|
|
|
warning: state.appState.warning,
|
2016-08-13 00:41:59 +02:00
|
|
|
buyView: state.appState.buyView,
|
2016-08-10 22:43:01 +02:00
|
|
|
network: state.metamask.network,
|
|
|
|
provider: state.metamask.provider,
|
2016-09-15 19:24:05 +02:00
|
|
|
context: state.appState.currentView.context,
|
2016-09-16 05:51:41 +02:00
|
|
|
isSubLoading: state.appState.isSubLoading,
|
2016-08-10 22:43:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
inherits(BuyButtonSubview, Component)
|
|
|
|
function BuyButtonSubview () {
|
|
|
|
Component.call(this)
|
|
|
|
}
|
|
|
|
|
|
|
|
BuyButtonSubview.prototype.render = function () {
|
2017-08-09 09:36:18 +02:00
|
|
|
return (
|
|
|
|
h('div', {
|
|
|
|
style: {
|
|
|
|
width: '100%',
|
|
|
|
},
|
|
|
|
}, [
|
|
|
|
this.headerSubview(),
|
|
|
|
this.primarySubview(),
|
|
|
|
])
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
BuyButtonSubview.prototype.headerSubview = function () {
|
2016-08-10 22:43:01 +02:00
|
|
|
const props = this.props
|
2016-09-16 05:51:41 +02:00
|
|
|
const isLoading = props.isSubLoading
|
2016-08-10 22:43:01 +02:00
|
|
|
return (
|
2017-08-09 09:36:18 +02:00
|
|
|
|
|
|
|
h('.flex-column', {
|
2017-04-18 18:21:24 +02:00
|
|
|
style: {
|
|
|
|
alignItems: 'center',
|
|
|
|
},
|
|
|
|
}, [
|
2017-08-09 09:36:18 +02:00
|
|
|
|
|
|
|
// header bar (back button, label)
|
2016-08-13 00:41:59 +02:00
|
|
|
h('.flex-row', {
|
|
|
|
style: {
|
|
|
|
alignItems: 'center',
|
|
|
|
justifyContent: 'center',
|
|
|
|
},
|
|
|
|
}, [
|
|
|
|
h('i.fa.fa-arrow-left.fa-lg.cursor-pointer.color-orange', {
|
2016-09-15 19:24:05 +02:00
|
|
|
onClick: this.backButtonContext.bind(this),
|
2016-08-13 00:41:59 +02:00
|
|
|
style: {
|
|
|
|
position: 'absolute',
|
|
|
|
left: '10px',
|
|
|
|
},
|
|
|
|
}),
|
2017-04-18 18:21:24 +02:00
|
|
|
h('h2.text-transform-uppercase.flex-center', {
|
|
|
|
style: {
|
|
|
|
width: '100vw',
|
|
|
|
background: 'rgb(235, 235, 235)',
|
|
|
|
color: 'rgb(174, 174, 174)',
|
|
|
|
paddingTop: '4px',
|
|
|
|
paddingBottom: '4px',
|
2016-11-04 20:02:00 +01:00
|
|
|
},
|
2018-03-29 17:00:44 +02:00
|
|
|
}, this.context.t('depositEth')),
|
2017-04-18 18:21:24 +02:00
|
|
|
]),
|
2017-08-09 09:36:18 +02:00
|
|
|
|
|
|
|
// loading indication
|
2017-04-18 18:21:24 +02:00
|
|
|
h('div', {
|
|
|
|
style: {
|
|
|
|
position: 'absolute',
|
|
|
|
top: '57vh',
|
|
|
|
left: '49vw',
|
|
|
|
},
|
|
|
|
}, [
|
2017-10-20 06:06:14 +02:00
|
|
|
isLoading && h(Loading),
|
2017-04-18 18:21:24 +02:00
|
|
|
]),
|
2017-08-09 09:36:18 +02:00
|
|
|
|
|
|
|
// account panel
|
2017-04-18 18:21:24 +02:00
|
|
|
h('div', {
|
|
|
|
style: {
|
|
|
|
width: '80%',
|
|
|
|
},
|
|
|
|
}, [
|
|
|
|
h(AccountPanel, {
|
|
|
|
showFullAddress: true,
|
|
|
|
identity: props.identity,
|
|
|
|
account: props.account,
|
|
|
|
}),
|
|
|
|
]),
|
2017-08-09 09:36:18 +02:00
|
|
|
|
|
|
|
h('.flex-row', {
|
2017-04-18 18:21:24 +02:00
|
|
|
style: {
|
2017-08-09 09:36:18 +02:00
|
|
|
alignItems: 'center',
|
|
|
|
justifyContent: 'center',
|
2017-04-18 18:21:24 +02:00
|
|
|
},
|
2017-08-09 09:36:18 +02:00
|
|
|
}, [
|
|
|
|
h('h3.text-transform-uppercase.flex-center', {
|
|
|
|
style: {
|
|
|
|
paddingLeft: '15px',
|
|
|
|
width: '100vw',
|
|
|
|
background: 'rgb(235, 235, 235)',
|
|
|
|
color: 'rgb(174, 174, 174)',
|
|
|
|
paddingTop: '4px',
|
|
|
|
paddingBottom: '4px',
|
|
|
|
},
|
2018-03-29 17:00:44 +02:00
|
|
|
}, this.context.t('selectService')),
|
2017-08-09 09:36:18 +02:00
|
|
|
]),
|
|
|
|
|
|
|
|
])
|
|
|
|
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BuyButtonSubview.prototype.primarySubview = function () {
|
|
|
|
const props = this.props
|
|
|
|
const network = props.network
|
|
|
|
|
|
|
|
switch (network) {
|
|
|
|
case 'loading':
|
|
|
|
return
|
2017-08-09 10:00:06 +02:00
|
|
|
|
2017-08-09 09:36:18 +02:00
|
|
|
case '1':
|
|
|
|
return this.mainnetSubview()
|
|
|
|
|
2017-08-09 10:00:06 +02:00
|
|
|
// Ropsten, Rinkeby, Kovan
|
2017-08-09 09:36:18 +02:00
|
|
|
case '3':
|
|
|
|
case '4':
|
|
|
|
case '42':
|
2018-04-12 23:17:36 +02:00
|
|
|
const networkName = getNetworkDisplayName(network)
|
2018-03-29 17:00:44 +02:00
|
|
|
const label = `${networkName} ${this.context.t('testFaucet')}`
|
2017-08-09 21:25:38 +02:00
|
|
|
return (
|
|
|
|
h('div.flex-column', {
|
2017-08-09 09:36:18 +02:00
|
|
|
style: {
|
2017-08-09 21:25:38 +02:00
|
|
|
alignItems: 'center',
|
|
|
|
margin: '20px 50px',
|
2017-08-09 09:36:18 +02:00
|
|
|
},
|
2017-08-09 21:25:38 +02:00
|
|
|
}, [
|
2017-08-09 09:36:18 +02:00
|
|
|
h('button.text-transform-uppercase', {
|
2017-08-09 21:25:38 +02:00
|
|
|
onClick: () => this.props.dispatch(actions.buyEth({ network })),
|
2017-08-09 09:36:18 +02:00
|
|
|
style: {
|
|
|
|
marginTop: '15px',
|
|
|
|
},
|
2017-08-09 21:25:38 +02:00
|
|
|
}, label),
|
|
|
|
// Kovan only: Dharma loans beta
|
|
|
|
network === '42' ? (
|
|
|
|
h('button.text-transform-uppercase', {
|
|
|
|
onClick: () => this.navigateTo('https://borrow.dharma.io/'),
|
|
|
|
style: {
|
|
|
|
marginTop: '15px',
|
|
|
|
},
|
2018-03-29 17:00:44 +02:00
|
|
|
}, this.context.t('borrowDharma'))
|
2017-08-09 21:25:38 +02:00
|
|
|
) : null,
|
2017-08-09 10:00:06 +02:00
|
|
|
])
|
|
|
|
)
|
2017-08-09 09:36:18 +02:00
|
|
|
|
|
|
|
default:
|
|
|
|
return (
|
2018-03-29 17:00:44 +02:00
|
|
|
h('h2.error', this.context.t('unknownNetworkId'))
|
2017-08-09 09:36:18 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
BuyButtonSubview.prototype.mainnetSubview = function () {
|
|
|
|
const props = this.props
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
|
|
|
h('.flex-column', {
|
|
|
|
style: {
|
|
|
|
alignItems: 'center',
|
|
|
|
},
|
|
|
|
}, [
|
|
|
|
|
2017-04-18 18:21:24 +02:00
|
|
|
h('.flex-row.selected-exchange', {
|
|
|
|
style: {
|
|
|
|
position: 'relative',
|
|
|
|
right: '35px',
|
|
|
|
marginTop: '20px',
|
|
|
|
marginBottom: '20px',
|
|
|
|
},
|
|
|
|
}, [
|
|
|
|
h(RadioList, {
|
|
|
|
defaultFocus: props.buyView.subview,
|
2017-04-24 20:56:31 +02:00
|
|
|
labels: [
|
2017-04-18 18:21:24 +02:00
|
|
|
'Coinbase',
|
|
|
|
'ShapeShift',
|
|
|
|
],
|
|
|
|
subtext: {
|
2018-03-29 17:00:44 +02:00
|
|
|
'Coinbase': `${this.context.t('crypto')}/${this.context.t('fiat')} (${this.context.t('usaOnly')})`,
|
|
|
|
'ShapeShift': this.context.t('crypto'),
|
2016-11-04 20:02:00 +01:00
|
|
|
},
|
2017-04-18 18:21:24 +02:00
|
|
|
onClick: this.radioHandler.bind(this),
|
|
|
|
}),
|
|
|
|
]),
|
2017-08-09 09:36:18 +02:00
|
|
|
|
2017-04-18 18:21:24 +02:00
|
|
|
h('h3.text-transform-uppercase', {
|
|
|
|
style: {
|
|
|
|
paddingLeft: '15px',
|
|
|
|
fontFamily: 'Montserrat Light',
|
|
|
|
width: '100vw',
|
|
|
|
background: 'rgb(235, 235, 235)',
|
|
|
|
color: 'rgb(174, 174, 174)',
|
|
|
|
paddingTop: '4px',
|
|
|
|
paddingBottom: '4px',
|
2016-08-10 22:43:01 +02:00
|
|
|
},
|
2017-04-18 18:21:24 +02:00
|
|
|
}, props.buyView.subview),
|
2017-08-09 09:36:18 +02:00
|
|
|
|
2016-08-10 22:43:01 +02:00
|
|
|
this.formVersionSubview(),
|
|
|
|
])
|
2017-08-09 09:36:18 +02:00
|
|
|
|
2016-08-10 22:43:01 +02:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
BuyButtonSubview.prototype.formVersionSubview = function () {
|
2017-04-05 03:23:46 +02:00
|
|
|
const network = this.props.network
|
|
|
|
if (network === '1') {
|
2016-08-13 00:41:59 +02:00
|
|
|
if (this.props.buyView.formView.coinbase) {
|
2016-08-10 22:43:01 +02:00
|
|
|
return h(CoinbaseForm, this.props)
|
2016-08-13 00:41:59 +02:00
|
|
|
} else if (this.props.buyView.formView.shapeshift) {
|
2016-08-10 22:43:01 +02:00
|
|
|
return h(ShapeshiftForm, this.props)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-13 00:41:59 +02:00
|
|
|
BuyButtonSubview.prototype.navigateTo = function (url) {
|
2017-04-01 03:04:13 +02:00
|
|
|
global.platform.openWindow({ url })
|
2016-08-13 00:41:59 +02:00
|
|
|
}
|
2016-09-15 19:24:05 +02:00
|
|
|
|
|
|
|
BuyButtonSubview.prototype.backButtonContext = function () {
|
|
|
|
if (this.props.context === 'confTx') {
|
2017-08-30 05:16:30 +02:00
|
|
|
this.props.dispatch(actions.showConfTxPage({transForward: false}))
|
2016-09-15 19:24:05 +02:00
|
|
|
} else {
|
|
|
|
this.props.dispatch(actions.goHome())
|
|
|
|
}
|
|
|
|
}
|
2017-04-18 18:21:24 +02:00
|
|
|
|
|
|
|
BuyButtonSubview.prototype.radioHandler = function (event) {
|
|
|
|
switch (event.target.title) {
|
|
|
|
case 'Coinbase':
|
|
|
|
return this.props.dispatch(actions.coinBaseSubview())
|
|
|
|
case 'ShapeShift':
|
|
|
|
return this.props.dispatch(actions.shapeShiftSubview(this.props.provider.type))
|
|
|
|
}
|
|
|
|
}
|