mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Convert AccountDetailsDropdown to ES6 class (#7777)
This commit is contained in:
parent
6947ff49e0
commit
7f47a42f55
@ -2,7 +2,6 @@ import React, { Component } from 'react'
|
||||
import PropTypes from 'prop-types'
|
||||
import { compose } from 'recompose'
|
||||
import { withRouter } from 'react-router-dom'
|
||||
import { inherits } from 'util'
|
||||
import { connect } from 'react-redux'
|
||||
import * as actions from '../../../store/actions'
|
||||
import { getSelectedIdentity, getRpcPrefsForCurrentProvider } from '../../../selectors/selectors'
|
||||
@ -10,13 +9,6 @@ import { CONNECTED_ROUTE } from '../../../helpers/constants/routes'
|
||||
import genAccountLink from '../../../../lib/account-link.js'
|
||||
import { Menu, Item, CloseArea } from './components/menu'
|
||||
|
||||
AccountDetailsDropdown.contextTypes = {
|
||||
t: PropTypes.func,
|
||||
metricsEvent: PropTypes.func,
|
||||
}
|
||||
|
||||
export default compose(withRouter, connect(mapStateToProps, mapDispatchToProps))(AccountDetailsDropdown)
|
||||
|
||||
function mapStateToProps (state) {
|
||||
return {
|
||||
selectedIdentity: getSelectedIdentity(state),
|
||||
@ -40,136 +32,150 @@ function mapDispatchToProps (dispatch) {
|
||||
}
|
||||
}
|
||||
|
||||
inherits(AccountDetailsDropdown, Component)
|
||||
function AccountDetailsDropdown () {
|
||||
Component.call(this)
|
||||
class AccountDetailsDropdown extends Component {
|
||||
static contextTypes = {
|
||||
t: PropTypes.func,
|
||||
metricsEvent: PropTypes.func,
|
||||
}
|
||||
|
||||
this.onClose = this.onClose.bind(this)
|
||||
}
|
||||
static propTypes = {
|
||||
selectedIdentity: PropTypes.object.isRequired,
|
||||
network: PropTypes.number.isRequired,
|
||||
keyrings: PropTypes.array.isRequired,
|
||||
showAccountDetailModal: PropTypes.func.isRequired,
|
||||
viewOnEtherscan: PropTypes.func.isRequired,
|
||||
showRemoveAccountConfirmationModal: PropTypes.func.isRequired,
|
||||
rpcPrefs: PropTypes.object.isRequired,
|
||||
history: PropTypes.object.isRequired,
|
||||
onClose: PropTypes.func.isRequired,
|
||||
}
|
||||
|
||||
AccountDetailsDropdown.prototype.onClose = function (e) {
|
||||
e.stopPropagation()
|
||||
this.props.onClose()
|
||||
}
|
||||
onClose = (e) => {
|
||||
e.stopPropagation()
|
||||
this.props.onClose()
|
||||
}
|
||||
|
||||
AccountDetailsDropdown.prototype.render = function AccountDetailsDropdown () {
|
||||
const {
|
||||
selectedIdentity,
|
||||
network,
|
||||
keyrings,
|
||||
showAccountDetailModal,
|
||||
viewOnEtherscan,
|
||||
showRemoveAccountConfirmationModal,
|
||||
rpcPrefs,
|
||||
history,
|
||||
} = this.props
|
||||
render () {
|
||||
const {
|
||||
selectedIdentity,
|
||||
network,
|
||||
keyrings,
|
||||
showAccountDetailModal,
|
||||
viewOnEtherscan,
|
||||
showRemoveAccountConfirmationModal,
|
||||
rpcPrefs,
|
||||
history,
|
||||
} = this.props
|
||||
|
||||
const address = selectedIdentity.address
|
||||
const address = selectedIdentity.address
|
||||
|
||||
const keyring = keyrings.find((kr) => {
|
||||
return kr.accounts.includes(address)
|
||||
})
|
||||
const keyring = keyrings.find((kr) => {
|
||||
return kr.accounts.includes(address)
|
||||
})
|
||||
|
||||
const isRemovable = keyring.type !== 'HD Key Tree'
|
||||
const isRemovable = keyring.type !== 'HD Key Tree'
|
||||
|
||||
return (
|
||||
<Menu className="account-details-dropdown" isShowing>
|
||||
<CloseArea onClick={this.onClose} />
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Clicked Expand View',
|
||||
},
|
||||
})
|
||||
global.platform.openExtensionInBrowser()
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={this.context.t('expandView')}
|
||||
icon={(
|
||||
<img alt="" src="images/expand.svg" style={{ height: '15px' }} />
|
||||
)}
|
||||
/>
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
showAccountDetailModal()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Viewed Account Details',
|
||||
},
|
||||
})
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={this.context.t('accountDetails')}
|
||||
icon={(
|
||||
<img src="images/info.svg" style={{ height: '15px' }} alt="" />
|
||||
)}
|
||||
/>
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Clicked View on Etherscan',
|
||||
},
|
||||
})
|
||||
viewOnEtherscan(address, network, rpcPrefs)
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={
|
||||
rpcPrefs.blockExplorerUrl
|
||||
? this.context.t('viewinExplorer')
|
||||
: this.context.t('viewOnEtherscan')
|
||||
}
|
||||
subText={
|
||||
rpcPrefs.blockExplorerUrl
|
||||
? rpcPrefs.blockExplorerUrl.match(/^https?:\/\/(.+)/)[1]
|
||||
return (
|
||||
<Menu className="account-details-dropdown" isShowing>
|
||||
<CloseArea onClick={this.onClose} />
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Clicked Expand View',
|
||||
},
|
||||
})
|
||||
global.platform.openExtensionInBrowser()
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={this.context.t('expandView')}
|
||||
icon={(
|
||||
<img alt="" src="images/expand.svg" style={{ height: '15px' }} />
|
||||
)}
|
||||
/>
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
showAccountDetailModal()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Viewed Account Details',
|
||||
},
|
||||
})
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={this.context.t('accountDetails')}
|
||||
icon={(
|
||||
<img src="images/info.svg" style={{ height: '15px' }} alt="" />
|
||||
)}
|
||||
/>
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Clicked View on Etherscan',
|
||||
},
|
||||
})
|
||||
viewOnEtherscan(address, network, rpcPrefs)
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={
|
||||
rpcPrefs.blockExplorerUrl
|
||||
? this.context.t('viewinExplorer')
|
||||
: this.context.t('viewOnEtherscan')
|
||||
}
|
||||
subText={
|
||||
rpcPrefs.blockExplorerUrl
|
||||
? rpcPrefs.blockExplorerUrl.match(/^https?:\/\/(.+)/)[1]
|
||||
: null
|
||||
}
|
||||
icon={(
|
||||
<img src="images/open-etherscan.svg" style={{ height: '15px' }} alt="" />
|
||||
)}
|
||||
/>
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Opened Connected Sites',
|
||||
},
|
||||
})
|
||||
history.push(CONNECTED_ROUTE)
|
||||
}}
|
||||
text={this.context.t('connectedSites')}
|
||||
icon={(
|
||||
<img src="images/connect-white.svg" style={{ height: '15px' }} alt="" />
|
||||
)}
|
||||
/>
|
||||
{
|
||||
isRemovable
|
||||
? (
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
showRemoveAccountConfirmationModal(selectedIdentity)
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={this.context.t('removeAccount')}
|
||||
icon={<img src="images/hide.svg" style={{ height: '15px' }} alt="" />}
|
||||
/>
|
||||
)
|
||||
: null
|
||||
}
|
||||
icon={(
|
||||
<img src="images/open-etherscan.svg" style={{ height: '15px' }} alt="" />
|
||||
)}
|
||||
/>
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
this.context.metricsEvent({
|
||||
eventOpts: {
|
||||
category: 'Navigation',
|
||||
action: 'Account Options',
|
||||
name: 'Opened Connected Sites',
|
||||
},
|
||||
})
|
||||
history.push(CONNECTED_ROUTE)
|
||||
}}
|
||||
text={this.context.t('connectedSites')}
|
||||
icon={(
|
||||
<img src="images/connect-white.svg" style={{ height: '15px' }} alt="" />
|
||||
)}
|
||||
/>
|
||||
{
|
||||
isRemovable
|
||||
? (
|
||||
<Item
|
||||
onClick={(e) => {
|
||||
e.stopPropagation()
|
||||
showRemoveAccountConfirmationModal(selectedIdentity)
|
||||
this.props.onClose()
|
||||
}}
|
||||
text={this.context.t('removeAccount')}
|
||||
icon={<img src="images/hide.svg" style={{ height: '15px' }} alt="" />}
|
||||
/>
|
||||
)
|
||||
: null
|
||||
}
|
||||
</Menu>
|
||||
)
|
||||
</Menu>
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
export default compose(withRouter, connect(mapStateToProps, mapDispatchToProps))(AccountDetailsDropdown)
|
||||
|
Loading…
Reference in New Issue
Block a user