1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-04 23:14:56 +01:00
metamask-extension/ui/app/components/modals/buy-options-modal.js

97 lines
3.1 KiB
JavaScript
Raw Normal View History

const Component = require('react').Component
const h = require('react-hyperscript')
const inherits = require('util').inherits
2018-03-16 01:29:45 +01:00
const connect = require('../../metamask-connect')
const actions = require('../../actions')
const networkNames = require('../../../../app/scripts/config.js').networkNames
2018-03-16 01:29:45 +01:00
const t = require('../../../i18n-helper').getMessage
function mapStateToProps (state) {
return {
network: state.metamask.network,
address: state.metamask.selectedAddress,
}
}
function mapDispatchToProps (dispatch) {
return {
toCoinbase: (address) => {
dispatch(actions.buyEth({ network: '1', address, amount: 0 }))
},
hideModal: () => {
dispatch(actions.hideModal())
2017-08-29 16:50:48 +02:00
},
showAccountDetailModal: () => {
dispatch(actions.showModal({ name: 'ACCOUNT_DETAILS' }))
},
toFaucet: network => dispatch(actions.buyEth({ network })),
}
}
inherits(BuyOptions, Component)
function BuyOptions () {
Component.call(this)
}
module.exports = connect(mapStateToProps, mapDispatchToProps)(BuyOptions)
BuyOptions.prototype.renderModalContentOption = function (title, header, onClick) {
return h('div.buy-modal-content-option', {
onClick,
}, [
h('div.buy-modal-content-option-title', {}, title),
h('div.buy-modal-content-option-subtitle', {}, header),
])
}
BuyOptions.prototype.render = function () {
const { network, toCoinbase, address, toFaucet } = this.props
2017-11-11 01:36:00 +01:00
const isTestNetwork = ['3', '4', '42'].find(n => n === network)
const networkName = networkNames[network]
return h('div', {}, [
h('div.buy-modal-content.transfers-subview', {
}, [
h('div.buy-modal-content-title-wrapper.flex-column.flex-center', {
style: {},
}, [
h('div.buy-modal-content-title', {
style: {},
2018-03-16 01:29:45 +01:00
}, t(this.props.localeMessages, 'transfers')),
h('div', {}, t(this.props.localeMessages, 'howToDeposit')),
]),
h('div.buy-modal-content-options.flex-column.flex-center', {}, [
2017-11-11 01:36:00 +01:00
isTestNetwork
2018-03-16 01:29:45 +01:00
? this.renderModalContentOption(networkName, t(this.props.localeMessages, 'testFaucet'), () => toFaucet(network))
: this.renderModalContentOption('Coinbase', t(this.props.localeMessages, 'depositFiat'), () => toCoinbase(address)),
2017-09-29 01:34:42 +02:00
// h('div.buy-modal-content-option', {}, [
// h('div.buy-modal-content-option-title', {}, 'Shapeshift'),
// h('div.buy-modal-content-option-subtitle', {}, 'Trade any digital asset for any other'),
// ]),,
this.renderModalContentOption(
2018-03-16 01:29:45 +01:00
t(this.props.localeMessages, 'directDeposit'),
t(this.props.localeMessages, 'depositFromAccount'),
() => this.goToAccountDetailsModal()
),
]),
h('button', {
style: {
background: 'white',
},
onClick: () => { this.props.hideModal() },
2018-03-16 01:29:45 +01:00
}, h('div.buy-modal-content-footer#buy-modal-content-footer-text', {}, t(this.props.localeMessages, 'cancel'))),
2017-08-29 16:50:48 +02:00
]),
])
}
BuyOptions.prototype.goToAccountDetailsModal = function () {
this.props.hideModal()
this.props.showAccountDetailModal()
}