mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
155 lines
4.4 KiB
JavaScript
155 lines
4.4 KiB
JavaScript
const Component = require('react').Component
|
|
const h = require('react-hyperscript')
|
|
const inherits = require('util').inherits
|
|
const connect = require('react-redux').connect
|
|
const actions = require('../actions')
|
|
const CoinbaseForm = require('./coinbase-form')
|
|
const ShapeshiftForm = require('./shapeshift-form')
|
|
const extension = require('extensionizer')
|
|
const Loading = require('./loading')
|
|
const TabBar = require('./tab-bar')
|
|
|
|
module.exports = connect(mapStateToProps)(BuyButtonSubview)
|
|
|
|
function mapStateToProps (state) {
|
|
return {
|
|
warning: state.appState.warning,
|
|
buyView: state.appState.buyView,
|
|
network: state.metamask.network,
|
|
provider: state.metamask.provider,
|
|
context: state.appState.currentView.context,
|
|
isSubLoading: state.appState.isSubLoading,
|
|
}
|
|
}
|
|
|
|
inherits(BuyButtonSubview, Component)
|
|
function BuyButtonSubview () {
|
|
Component.call(this)
|
|
}
|
|
|
|
BuyButtonSubview.prototype.render = function () {
|
|
const props = this.props
|
|
const isLoading = props.isSubLoading
|
|
|
|
return (
|
|
h('.buy-eth-section', [
|
|
// back button
|
|
h('.flex-row', {
|
|
style: {
|
|
alignItems: 'center',
|
|
justifyContent: 'center',
|
|
},
|
|
}, [
|
|
h('i.fa.fa-arrow-left.fa-lg.cursor-pointer.color-orange', {
|
|
onClick: this.backButtonContext.bind(this),
|
|
style: {
|
|
position: 'absolute',
|
|
left: '10px',
|
|
},
|
|
}),
|
|
h('h2.page-subtitle', 'Buy Eth'),
|
|
]),
|
|
|
|
h(Loading, { isLoading }),
|
|
|
|
h(TabBar, {
|
|
tabs: [
|
|
{
|
|
content: [
|
|
'Coinbase',
|
|
h('a', {
|
|
onClick: (event) => this.navigateTo('https://github.com/MetaMask/faq/blob/master/COINBASE.md'),
|
|
}, [
|
|
h('i.fa.fa-question-circle', {
|
|
style: {
|
|
margin: '0px 5px',
|
|
},
|
|
}),
|
|
]),
|
|
],
|
|
key: 'coinbase',
|
|
},
|
|
{
|
|
content: [
|
|
'Shapeshift',
|
|
h('a', {
|
|
href: 'https://github.com/MetaMask/faq/blob/master/COINBASE.md',
|
|
onClick: (event) => this.navigateTo('https://info.shapeshift.io/about'),
|
|
}, [
|
|
h('i.fa.fa-question-circle', {
|
|
style: {
|
|
margin: '0px 5px',
|
|
},
|
|
}),
|
|
]),
|
|
],
|
|
key: 'shapeshift',
|
|
},
|
|
],
|
|
defaultTab: 'coinbase',
|
|
tabSelected: (key) => {
|
|
switch (key) {
|
|
case 'coinbase':
|
|
props.dispatch(actions.coinBaseSubview())
|
|
break
|
|
case 'shapeshift':
|
|
props.dispatch(actions.shapeShiftSubview(props.provider.type))
|
|
break
|
|
}
|
|
},
|
|
}),
|
|
|
|
this.formVersionSubview(),
|
|
])
|
|
)
|
|
}
|
|
|
|
BuyButtonSubview.prototype.formVersionSubview = function () {
|
|
if (this.props.network === '1') {
|
|
if (this.props.buyView.formView.coinbase) {
|
|
return h(CoinbaseForm, this.props)
|
|
} else if (this.props.buyView.formView.shapeshift) {
|
|
return h(ShapeshiftForm, this.props)
|
|
}
|
|
} else {
|
|
return h('div.flex-column', {
|
|
style: {
|
|
alignItems: 'center',
|
|
margin: '50px',
|
|
},
|
|
}, [
|
|
h('h3.text-transform-uppercase', {
|
|
style: {
|
|
width: '225px',
|
|
marginBottom: '15px',
|
|
},
|
|
}, 'In order to access this feature, please switch to the Main Network'),
|
|
((this.props.network === '3') || (this.props.network === '42')) ? h('h3.text-transform-uppercase', 'or go to the') : null,
|
|
(this.props.network === '3') ? h('button.text-transform-uppercase', {
|
|
onClick: () => this.props.dispatch(actions.buyEth()),
|
|
style: {
|
|
marginTop: '15px',
|
|
},
|
|
}, 'Ropsten Test Faucet') : null,
|
|
(this.props.network === '42') ? h('button.text-transform-uppercase', {
|
|
onClick: () => this.props.dispatch(actions.buyEth()),
|
|
style: {
|
|
marginTop: '15px',
|
|
},
|
|
}, 'Kovan Test Faucet') : null,
|
|
])
|
|
}
|
|
}
|
|
|
|
BuyButtonSubview.prototype.navigateTo = function (url) {
|
|
extension.tabs.create({ url })
|
|
}
|
|
|
|
BuyButtonSubview.prototype.backButtonContext = function () {
|
|
if (this.props.context === 'confTx') {
|
|
this.props.dispatch(actions.showConfTxPage(false))
|
|
} else {
|
|
this.props.dispatch(actions.goHome())
|
|
}
|
|
}
|