2017-08-13 19:49:41 +02:00
|
|
|
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')
|
2017-08-14 10:31:27 +02:00
|
|
|
const Dropdown = require('./components/dropdown').Dropdown
|
|
|
|
const DropdownMenuItem = require('./components/dropdown').DropdownMenuItem
|
2017-08-13 19:49:41 +02:00
|
|
|
|
|
|
|
function mapStateToProps (state) {
|
|
|
|
return {
|
2017-08-13 22:15:21 +02:00
|
|
|
provider: state.metamask.provider,
|
|
|
|
frequentRpcList: state.metamask.frequentRpcList || [],
|
|
|
|
networkDropdownOpen: state.appState.networkDropdownOpen,
|
2017-08-13 19:49:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function mapDispatchToProps (dispatch) {
|
|
|
|
return {
|
|
|
|
hideModal: () => {
|
|
|
|
dispatch(actions.hideModal())
|
|
|
|
},
|
2017-08-13 22:15:21 +02:00
|
|
|
setProviderType: (type) => {
|
|
|
|
dispatch(actions.setProviderType(type))
|
|
|
|
},
|
|
|
|
setDefaultRpcTarget: () => {
|
|
|
|
dispatch(actions.setDefaultRpcTarget(type))
|
|
|
|
},
|
|
|
|
setRpcTarget: (target) => {
|
|
|
|
dispatch(actions.setRpcTarget(target))
|
|
|
|
},
|
|
|
|
showConfigPage: () => {
|
|
|
|
dispatch(actions.showConfigPage())
|
|
|
|
},
|
|
|
|
showNetworkDropdown: () => {dispatch(actions.showNetworkDropdown())},
|
|
|
|
hideNetworkDropdown: () => {dispatch(actions.hideNetworkDropdown())},
|
2017-08-13 19:49:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inherits(NetworkDropdown, Component)
|
|
|
|
function NetworkDropdown () {
|
|
|
|
Component.call(this)
|
|
|
|
}
|
|
|
|
|
2017-08-13 22:18:08 +02:00
|
|
|
module.exports = connect(mapStateToProps, mapDispatchToProps)(NetworkDropdown)
|
|
|
|
|
2017-08-13 19:49:41 +02:00
|
|
|
// TODO: specify default props and proptypes
|
|
|
|
NetworkDropdown.prototype.render = function () {
|
|
|
|
const props = this.props
|
|
|
|
const { provider: { type: providerType, rpcTarget: activeNetwork } } = props
|
|
|
|
const rpcList = props.frequentRpcList
|
|
|
|
const state = this.state || {}
|
2017-08-13 22:15:21 +02:00
|
|
|
const isOpen = this.props.networkDropdownOpen
|
|
|
|
|
2017-08-13 19:49:41 +02:00
|
|
|
return h(Dropdown, {
|
|
|
|
useCssTransition: true,
|
|
|
|
isOpen,
|
|
|
|
onClickOutside: (event) => {
|
|
|
|
const { classList } = event.target
|
|
|
|
const isNotToggleElement = [
|
|
|
|
classList.contains('menu-icon'),
|
|
|
|
classList.contains('network-name'),
|
|
|
|
classList.contains('network-indicator'),
|
|
|
|
].filter(bool => bool).length === 0
|
|
|
|
// classes from three constituent nodes of the toggle element
|
|
|
|
|
|
|
|
if (isNotToggleElement) {
|
2017-08-13 22:15:21 +02:00
|
|
|
this.props.hideNetworkDropdown()
|
2017-08-13 19:49:41 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
zIndex: 11,
|
|
|
|
style: {
|
|
|
|
position: 'absolute',
|
|
|
|
right: '2px',
|
|
|
|
top: '38px',
|
|
|
|
},
|
|
|
|
innerStyle: {
|
|
|
|
padding: '2px 16px 2px 0px',
|
|
|
|
},
|
|
|
|
}, [
|
|
|
|
|
|
|
|
h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: 'main',
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => props.setProviderType('mainnet'),
|
2017-08-13 19:49:41 +02:00
|
|
|
style: {
|
|
|
|
fontSize: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[
|
|
|
|
h('.menu-icon.diamond'),
|
|
|
|
'Main Ethereum Network',
|
|
|
|
providerType === 'mainnet' ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
|
|
|
|
h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: 'ropsten',
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => props.setProviderType('ropsten'),
|
2017-08-13 19:49:41 +02:00
|
|
|
style: {
|
|
|
|
fontSize: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[
|
|
|
|
h('.menu-icon.red-dot'),
|
|
|
|
'Ropsten Test Network',
|
|
|
|
providerType === 'ropsten' ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
|
|
|
|
h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: 'kovan',
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => props.setProviderType('kovan'),
|
2017-08-13 19:49:41 +02:00
|
|
|
style: {
|
|
|
|
fontSize: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[
|
|
|
|
h('.menu-icon.hollow-diamond'),
|
|
|
|
'Kovan Test Network',
|
|
|
|
providerType === 'kovan' ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
|
|
|
|
h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: 'rinkeby',
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => propssetProviderType('rinkeby'),
|
2017-08-13 19:49:41 +02:00
|
|
|
style: {
|
|
|
|
fontSize: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[
|
|
|
|
h('.menu-icon.golden-square'),
|
|
|
|
'Rinkeby Test Network',
|
|
|
|
providerType === 'rinkeby' ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
|
|
|
|
h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: 'default',
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => props.setDefaultRpcTarget(),
|
2017-08-13 19:49:41 +02:00
|
|
|
style: {
|
|
|
|
fontSize: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[
|
|
|
|
h('i.fa.fa-question-circle.fa-lg.menu-icon'),
|
|
|
|
'Localhost 8545',
|
|
|
|
activeNetwork === 'http://localhost:8545' ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
|
|
|
|
this.renderCustomOption(props.provider),
|
|
|
|
this.renderCommonRpc(rpcList, props.provider),
|
|
|
|
|
|
|
|
h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => this.props.showConfigPage(),
|
2017-08-13 19:49:41 +02:00
|
|
|
style: {
|
|
|
|
fontSize: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
[
|
|
|
|
h('i.fa.fa-question-circle.fa-lg.menu-icon'),
|
|
|
|
'Custom RPC',
|
|
|
|
activeNetwork === 'custom' ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
),
|
|
|
|
|
|
|
|
])
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
NetworkDropdown.prototype.getNetworkName = function () {
|
|
|
|
const { provider } = this.props
|
|
|
|
const providerName = provider.type
|
|
|
|
|
|
|
|
let name
|
|
|
|
|
|
|
|
if (providerName === 'mainnet') {
|
|
|
|
name = 'Main Ethereum Network'
|
|
|
|
} else if (providerName === 'ropsten') {
|
|
|
|
name = 'Ropsten Test Network'
|
|
|
|
} else if (providerName === 'kovan') {
|
|
|
|
name = 'Kovan Test Network'
|
|
|
|
} else if (providerName === 'rinkeby') {
|
|
|
|
name = 'Rinkeby Test Network'
|
|
|
|
} else {
|
|
|
|
name = 'Unknown Private Network'
|
|
|
|
}
|
|
|
|
|
|
|
|
return name
|
|
|
|
}
|
|
|
|
|
|
|
|
NetworkDropdown.prototype.renderCommonRpc = function (rpcList, provider) {
|
|
|
|
const props = this.props
|
|
|
|
const rpcTarget = provider.rpcTarget
|
|
|
|
|
|
|
|
return rpcList.map((rpc) => {
|
|
|
|
if ((rpc === 'http://localhost:8545') || (rpc === rpcTarget)) {
|
|
|
|
return null
|
|
|
|
} else {
|
|
|
|
return h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: `common${rpc}`,
|
2017-08-13 22:15:21 +02:00
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
|
|
|
onClick: () => props.setRpcTarget(rpc),
|
2017-08-13 19:49:41 +02:00
|
|
|
},
|
|
|
|
[
|
|
|
|
h('i.fa.fa-question-circle.fa-lg.menu-icon'),
|
|
|
|
rpc,
|
|
|
|
rpcTarget === rpc ? h('.check', '✓') : null,
|
|
|
|
]
|
|
|
|
)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
NetworkDropdown.prototype.renderCustomOption = function (provider) {
|
|
|
|
const { rpcTarget, type } = provider
|
|
|
|
const props = this.props
|
|
|
|
|
|
|
|
if (type !== 'rpc') return null
|
|
|
|
|
|
|
|
// Concatenate long URLs
|
|
|
|
let label = rpcTarget
|
|
|
|
if (rpcTarget.length > 31) {
|
|
|
|
label = label.substr(0, 34) + '...'
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (rpcTarget) {
|
|
|
|
|
|
|
|
case 'http://localhost:8545':
|
|
|
|
return null
|
|
|
|
|
|
|
|
default:
|
|
|
|
return h(
|
|
|
|
DropdownMenuItem,
|
|
|
|
{
|
|
|
|
key: rpcTarget,
|
2017-08-13 22:15:21 +02:00
|
|
|
onClick: () => props.setRpcTarget(rpcTarget),
|
|
|
|
closeMenu: () => this.props.hideNetworkDropdown(),
|
2017-08-13 19:49:41 +02:00
|
|
|
},
|
|
|
|
[
|
|
|
|
h('i.fa.fa-question-circle.fa-lg.menu-icon'),
|
|
|
|
label,
|
|
|
|
h('.check', '✓'),
|
|
|
|
]
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|