1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Use ES6 exports for selectors (#7626)

This lets us get rid of the big `selectors` object that was unpleasant
to maintain.
This commit is contained in:
Mark Stacey 2019-12-03 16:04:28 -04:00 committed by GitHub
parent b4fd7aea32
commit d9bdba5948
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 76 additions and 143 deletions

View File

@ -1,5 +1,5 @@
const assert = require('assert') const assert = require('assert')
const selectors = require('../../../../ui/app/selectors/selectors') import * as selectors from '../../../../ui/app/selectors/selectors'
const mockState = require('../../../data/mock-state.json') const mockState = require('../../../data/mock-state.json')
const Eth = require('ethjs') const Eth = require('ethjs')

View File

@ -1,12 +1,12 @@
import { connect } from 'react-redux' import { connect } from 'react-redux'
import SelectedAccount from './selected-account.component' import SelectedAccount from './selected-account.component'
const selectors = require('../../../selectors/selectors') const { getSelectedAddress, getSelectedIdentity } = require('../../../selectors/selectors')
const mapStateToProps = state => { const mapStateToProps = state => {
return { return {
selectedAddress: selectors.getSelectedAddress(state), selectedAddress: getSelectedAddress(state),
selectedIdentity: selectors.getSelectedIdentity(state), selectedIdentity: getSelectedIdentity(state),
network: state.metamask.network, network: state.metamask.network,
} }
} }

View File

@ -4,14 +4,14 @@ import TokenCell from './token-cell'
const inherits = require('util').inherits const inherits = require('util').inherits
const TokenTracker = require('eth-token-tracker') const TokenTracker = require('eth-token-tracker')
const connect = require('react-redux').connect const connect = require('react-redux').connect
const selectors = require('../../selectors/selectors') const { getSelectedAddress } = require('../../selectors/selectors')
const log = require('loglevel') const log = require('loglevel')
function mapStateToProps (state) { function mapStateToProps (state) {
return { return {
network: state.metamask.network, network: state.metamask.network,
tokens: state.metamask.tokens, tokens: state.metamask.tokens,
userAddress: selectors.getSelectedAddress(state), userAddress: getSelectedAddress(state),
assetImages: state.metamask.assetImages, assetImages: state.metamask.assetImages,
} }
} }

View File

@ -3,17 +3,17 @@ import { withRouter } from 'react-router-dom'
import { compose } from 'recompose' import { compose } from 'recompose'
import WalletView from './wallet-view.component' import WalletView from './wallet-view.component'
import {showSendPage, hideSidebar, setSelectedToken, showAddTokenPage} from '../../../store/actions' import {showSendPage, hideSidebar, setSelectedToken, showAddTokenPage} from '../../../store/actions'
import * as selectors from '../../../selectors/selectors' import { getMetaMaskAccounts, getSelectedAddress, getSelectedAccount } from '../../../selectors/selectors'
function mapStateToProps (state) { function mapStateToProps (state) {
return { return {
network: state.metamask.network, network: state.metamask.network,
sidebarOpen: state.appState.sidebar.isOpen, sidebarOpen: state.appState.sidebar.isOpen,
identities: state.metamask.identities, identities: state.metamask.identities,
accounts: selectors.getMetaMaskAccounts(state), accounts: getMetaMaskAccounts(state),
keyrings: state.metamask.keyrings, keyrings: state.metamask.keyrings,
selectedAddress: selectors.getSelectedAddress(state), selectedAddress: getSelectedAddress(state),
selectedAccount: selectors.getSelectedAccount(state), selectedAccount: getSelectedAccount(state),
selectedTokenAddress: state.metamask.selectedTokenAddress, selectedTokenAddress: state.metamask.selectedTokenAddress,
} }
} }

View File

@ -2,11 +2,11 @@ import { connect } from 'react-redux'
import { compose } from 'recompose' import { compose } from 'recompose'
import withTokenTracker from '../../../helpers/higher-order-components/with-token-tracker' import withTokenTracker from '../../../helpers/higher-order-components/with-token-tracker'
import TokenBalance from './token-balance.component' import TokenBalance from './token-balance.component'
import selectors from '../../../selectors/selectors' import { getSelectedAddress } from '../../../selectors/selectors'
const mapStateToProps = state => { const mapStateToProps = state => {
return { return {
userAddress: selectors.getSelectedAddress(state), userAddress: getSelectedAddress(state),
} }
} }

View File

@ -2,10 +2,8 @@ import { NETWORK_TYPES } from '../helpers/constants/common'
import { mapObjectValues } from '../../../app/scripts/lib/util' import { mapObjectValues } from '../../../app/scripts/lib/util'
import { stripHexPrefix, addHexPrefix } from 'ethereumjs-util' import { stripHexPrefix, addHexPrefix } from 'ethereumjs-util'
const abi = require('human-standard-token-abi') import abi from 'human-standard-token-abi'
const { import { multiplyCurrencies } from '../helpers/utils/conversion-util'
multiplyCurrencies,
} = require('../helpers/utils/conversion-util')
import { import {
addressSlicer, addressSlicer,
checksumAddress, checksumAddress,
@ -13,78 +11,13 @@ import {
getOriginFromUrl, getOriginFromUrl,
} from '../helpers/utils/util' } from '../helpers/utils/util'
const selectors = { export function getNetworkIdentifier (state) {
getSelectedAddress,
getSelectedIdentity,
getSelectedAccount,
getSelectedToken,
getSelectedTokenExchangeRate,
getSelectedTokenAssetImage,
getAssetImages,
getTokenExchangeRate,
conversionRateSelector,
accountsWithSendEtherInfoSelector,
getAccountsWithLabels,
getCurrentAccountWithSendEtherInfo,
getGasIsLoading,
getForceGasMin,
getAddressBook,
getSendFrom,
getCurrentCurrency,
getNativeCurrency,
getSendAmount,
getSelectedTokenToFiatRate,
getSelectedTokenContract,
getSendMaxModeState,
getCurrentViewContext,
getTotalUnapprovedCount,
preferencesSelector,
getMetaMaskAccounts,
getCurrentEthBalance,
getNetworkIdentifier,
isBalanceCached,
getAdvancedInlineGasShown,
getUseNonceField,
getCustomNonceValue,
getIsMainnet,
getCurrentNetworkId,
getSelectedAsset,
getCurrentKeyring,
getAccountType,
getNumberOfAccounts,
getNumberOfTokens,
getDaiV1Token,
isEthereumNetwork,
getPermissionsRequests,
getPermissionsDescriptions,
getDomainMetadata,
getActiveTab,
getMetaMetricState,
getRpcPrefsForCurrentProvider,
getKnownMethodData,
getAddressBookEntry,
getAddressBookEntryName,
getFeatureFlags,
getFirstPermissionRequest,
hasPermissionRequests,
getRenderablePermissionsDomains,
getPermissionsDomains,
getAddressConnectedDomainMap,
getDomainToConnectedAddressMap,
getOriginOfCurrentTab,
getAddressConnectedToCurrentTab,
getLastConnectedInfo,
}
module.exports = selectors
function getNetworkIdentifier (state) {
const { metamask: { provider: { type, nickname, rpcTarget } } } = state const { metamask: { provider: { type, nickname, rpcTarget } } } = state
return nickname || rpcTarget || type return nickname || rpcTarget || type
} }
function getCurrentKeyring (state) { export function getCurrentKeyring (state) {
const identity = getSelectedIdentity(state) const identity = getSelectedIdentity(state)
if (!identity) { if (!identity) {
@ -101,7 +34,7 @@ function getCurrentKeyring (state) {
return keyring return keyring
} }
function getAccountType (state) { export function getAccountType (state) {
const currentKeyring = getCurrentKeyring(state) const currentKeyring = getCurrentKeyring(state)
const type = currentKeyring && currentKeyring.type const type = currentKeyring && currentKeyring.type
@ -116,38 +49,38 @@ function getAccountType (state) {
} }
} }
function getSelectedAsset (state) { export function getSelectedAsset (state) {
const selectedToken = getSelectedToken(state) const selectedToken = getSelectedToken(state)
return selectedToken && selectedToken.symbol || 'ETH' return selectedToken && selectedToken.symbol || 'ETH'
} }
function getCurrentNetworkId (state) { export function getCurrentNetworkId (state) {
return state.metamask.network return state.metamask.network
} }
function getSelectedAddress (state) { export function getSelectedAddress (state) {
const selectedAddress = state.metamask.selectedAddress || Object.keys(getMetaMaskAccounts(state))[0] const selectedAddress = state.metamask.selectedAddress || Object.keys(getMetaMaskAccounts(state))[0]
return selectedAddress return selectedAddress
} }
function getSelectedIdentity (state) { export function getSelectedIdentity (state) {
const selectedAddress = getSelectedAddress(state) const selectedAddress = getSelectedAddress(state)
const identities = state.metamask.identities const identities = state.metamask.identities
return identities[selectedAddress] return identities[selectedAddress]
} }
function getNumberOfAccounts (state) { export function getNumberOfAccounts (state) {
return Object.keys(state.metamask.accounts).length return Object.keys(state.metamask.accounts).length
} }
function getNumberOfTokens (state) { export function getNumberOfTokens (state) {
const tokens = state.metamask.tokens const tokens = state.metamask.tokens
return tokens ? tokens.length : 0 return tokens ? tokens.length : 0
} }
function getMetaMaskAccounts (state) { export function getMetaMaskAccounts (state) {
const currentAccounts = state.metamask.accounts const currentAccounts = state.metamask.accounts
const cachedBalances = state.metamask.cachedBalances[state.metamask.network] const cachedBalances = state.metamask.cachedBalances[state.metamask.network]
const selectedAccounts = {} const selectedAccounts = {}
@ -166,28 +99,28 @@ function getMetaMaskAccounts (state) {
return selectedAccounts return selectedAccounts
} }
function isBalanceCached (state) { export function isBalanceCached (state) {
const selectedAccountBalance = state.metamask.accounts[getSelectedAddress(state)].balance const selectedAccountBalance = state.metamask.accounts[getSelectedAddress(state)].balance
const cachedBalance = getSelectedAccountCachedBalance(state) const cachedBalance = getSelectedAccountCachedBalance(state)
return Boolean(!selectedAccountBalance && cachedBalance) return Boolean(!selectedAccountBalance && cachedBalance)
} }
function getSelectedAccountCachedBalance (state) { export function getSelectedAccountCachedBalance (state) {
const cachedBalances = state.metamask.cachedBalances[state.metamask.network] const cachedBalances = state.metamask.cachedBalances[state.metamask.network]
const selectedAddress = getSelectedAddress(state) const selectedAddress = getSelectedAddress(state)
return cachedBalances && cachedBalances[selectedAddress] return cachedBalances && cachedBalances[selectedAddress]
} }
function getSelectedAccount (state) { export function getSelectedAccount (state) {
const accounts = getMetaMaskAccounts(state) const accounts = getMetaMaskAccounts(state)
const selectedAddress = getSelectedAddress(state) const selectedAddress = getSelectedAddress(state)
return accounts[selectedAddress] return accounts[selectedAddress]
} }
function getSelectedToken (state) { export function getSelectedToken (state) {
const tokens = state.metamask.tokens || [] const tokens = state.metamask.tokens || []
const selectedTokenAddress = state.metamask.selectedTokenAddress const selectedTokenAddress = state.metamask.selectedTokenAddress
const selectedToken = tokens.filter(({ address }) => address === selectedTokenAddress)[0] const selectedToken = tokens.filter(({ address }) => address === selectedTokenAddress)[0]
@ -196,35 +129,35 @@ function getSelectedToken (state) {
return selectedToken || sendToken || null return selectedToken || sendToken || null
} }
function getSelectedTokenExchangeRate (state) { export function getSelectedTokenExchangeRate (state) {
const contractExchangeRates = state.metamask.contractExchangeRates const contractExchangeRates = state.metamask.contractExchangeRates
const selectedToken = getSelectedToken(state) || {} const selectedToken = getSelectedToken(state) || {}
const { address } = selectedToken const { address } = selectedToken
return contractExchangeRates[address] || 0 return contractExchangeRates[address] || 0
} }
function getSelectedTokenAssetImage (state) { export function getSelectedTokenAssetImage (state) {
const assetImages = state.metamask.assetImages || {} const assetImages = state.metamask.assetImages || {}
const selectedToken = getSelectedToken(state) || {} const selectedToken = getSelectedToken(state) || {}
const { address } = selectedToken const { address } = selectedToken
return assetImages[address] return assetImages[address]
} }
function getAssetImages (state) { export function getAssetImages (state) {
const assetImages = state.metamask.assetImages || {} const assetImages = state.metamask.assetImages || {}
return assetImages return assetImages
} }
function getTokenExchangeRate (state, address) { export function getTokenExchangeRate (state, address) {
const contractExchangeRates = state.metamask.contractExchangeRates const contractExchangeRates = state.metamask.contractExchangeRates
return contractExchangeRates[address] || 0 return contractExchangeRates[address] || 0
} }
function conversionRateSelector (state) { export function conversionRateSelector (state) {
return state.metamask.conversionRate return state.metamask.conversionRate
} }
function getAddressBook (state) { export function getAddressBook (state) {
const network = state.metamask.network const network = state.metamask.network
if (!state.metamask.addressBook[network]) { if (!state.metamask.addressBook[network]) {
return [] return []
@ -232,24 +165,24 @@ function getAddressBook (state) {
return Object.values(state.metamask.addressBook[network]) return Object.values(state.metamask.addressBook[network])
} }
function getAddressBookEntry (state, address) { export function getAddressBookEntry (state, address) {
const addressBook = getAddressBook(state) const addressBook = getAddressBook(state)
const entry = addressBook.find(contact => contact.address === checksumAddress(address)) const entry = addressBook.find(contact => contact.address === checksumAddress(address))
return entry return entry
} }
function getAddressBookEntryName (state, address) { export function getAddressBookEntryName (state, address) {
const entry = getAddressBookEntry(state, address) || state.metamask.identities[address] const entry = getAddressBookEntry(state, address) || state.metamask.identities[address]
return entry && entry.name !== '' ? entry.name : addressSlicer(address) return entry && entry.name !== '' ? entry.name : addressSlicer(address)
} }
function getDaiV1Token (state) { export function getDaiV1Token (state) {
const OLD_DAI_CONTRACT_ADDRESS = '0x89d24A6b4CcB1B6fAA2625fE562bDD9a23260359' const OLD_DAI_CONTRACT_ADDRESS = '0x89d24A6b4CcB1B6fAA2625fE562bDD9a23260359'
const tokens = state.metamask.tokens || [] const tokens = state.metamask.tokens || []
return tokens.find(({address}) => checksumAddress(address) === OLD_DAI_CONTRACT_ADDRESS) return tokens.find(({address}) => checksumAddress(address) === OLD_DAI_CONTRACT_ADDRESS)
} }
function accountsWithSendEtherInfoSelector (state) { export function accountsWithSendEtherInfoSelector (state) {
const accounts = getMetaMaskAccounts(state) const accounts = getMetaMaskAccounts(state)
const { identities } = state.metamask const { identities } = state.metamask
@ -260,7 +193,7 @@ function accountsWithSendEtherInfoSelector (state) {
return accountsWithSendEtherInfo return accountsWithSendEtherInfo
} }
function getAccountsWithLabels (state) { export function getAccountsWithLabels (state) {
const accountsWithoutLabel = accountsWithSendEtherInfoSelector(state) const accountsWithoutLabel = accountsWithSendEtherInfoSelector(state)
const accountsWithLabels = accountsWithoutLabel.map(account => { const accountsWithLabels = accountsWithoutLabel.map(account => {
const { address, name, balance } = account const { address, name, balance } = account
@ -275,46 +208,46 @@ function getAccountsWithLabels (state) {
return accountsWithLabels return accountsWithLabels
} }
function getCurrentAccountWithSendEtherInfo (state) { export function getCurrentAccountWithSendEtherInfo (state) {
const currentAddress = getSelectedAddress(state) const currentAddress = getSelectedAddress(state)
const accounts = accountsWithSendEtherInfoSelector(state) const accounts = accountsWithSendEtherInfoSelector(state)
return accounts.find(({ address }) => address === currentAddress) return accounts.find(({ address }) => address === currentAddress)
} }
function getCurrentEthBalance (state) { export function getCurrentEthBalance (state) {
return getCurrentAccountWithSendEtherInfo(state).balance return getCurrentAccountWithSendEtherInfo(state).balance
} }
function getGasIsLoading (state) { export function getGasIsLoading (state) {
return state.appState.gasIsLoading return state.appState.gasIsLoading
} }
function getForceGasMin (state) { export function getForceGasMin (state) {
return state.metamask.send.forceGasMin return state.metamask.send.forceGasMin
} }
function getSendFrom (state) { export function getSendFrom (state) {
return state.metamask.send.from return state.metamask.send.from
} }
function getSendAmount (state) { export function getSendAmount (state) {
return state.metamask.send.amount return state.metamask.send.amount
} }
function getSendMaxModeState (state) { export function getSendMaxModeState (state) {
return state.metamask.send.maxModeOn return state.metamask.send.maxModeOn
} }
function getCurrentCurrency (state) { export function getCurrentCurrency (state) {
return state.metamask.currentCurrency return state.metamask.currentCurrency
} }
function getNativeCurrency (state) { export function getNativeCurrency (state) {
return state.metamask.nativeCurrency return state.metamask.nativeCurrency
} }
function getSelectedTokenToFiatRate (state) { export function getSelectedTokenToFiatRate (state) {
const selectedTokenExchangeRate = getSelectedTokenExchangeRate(state) const selectedTokenExchangeRate = getSelectedTokenExchangeRate(state)
const conversionRate = conversionRateSelector(state) const conversionRate = conversionRateSelector(state)
@ -327,19 +260,19 @@ function getSelectedTokenToFiatRate (state) {
return tokenToFiatRate return tokenToFiatRate
} }
function getSelectedTokenContract (state) { export function getSelectedTokenContract (state) {
const selectedToken = getSelectedToken(state) const selectedToken = getSelectedToken(state)
return selectedToken return selectedToken
? global.eth.contract(abi).at(selectedToken.address) ? global.eth.contract(abi).at(selectedToken.address)
: null : null
} }
function getCurrentViewContext (state) { export function getCurrentViewContext (state) {
const { currentView = {} } = state.appState const { currentView = {} } = state.appState
return currentView.context return currentView.context
} }
function getTotalUnapprovedCount ({ metamask }) { export function getTotalUnapprovedCount ({ metamask }) {
const { const {
unapprovedTxs = {}, unapprovedTxs = {},
unapprovedMsgCount, unapprovedMsgCount,
@ -351,12 +284,12 @@ function getTotalUnapprovedCount ({ metamask }) {
unapprovedTypedMessagesCount unapprovedTypedMessagesCount
} }
function getIsMainnet (state) { export function getIsMainnet (state) {
const networkType = getNetworkIdentifier(state) const networkType = getNetworkIdentifier(state)
return networkType === NETWORK_TYPES.MAINNET return networkType === NETWORK_TYPES.MAINNET
} }
function isEthereumNetwork (state) { export function isEthereumNetwork (state) {
const networkType = getNetworkIdentifier(state) const networkType = getNetworkIdentifier(state)
const { const {
KOVAN, KOVAN,
@ -369,39 +302,39 @@ function isEthereumNetwork (state) {
return [ KOVAN, MAINNET, RINKEBY, ROPSTEN, GOERLI].includes(networkType) return [ KOVAN, MAINNET, RINKEBY, ROPSTEN, GOERLI].includes(networkType)
} }
function preferencesSelector ({ metamask }) { export function preferencesSelector ({ metamask }) {
return metamask.preferences return metamask.preferences
} }
function getAdvancedInlineGasShown (state) { export function getAdvancedInlineGasShown (state) {
return Boolean(state.metamask.featureFlags.advancedInlineGas) return Boolean(state.metamask.featureFlags.advancedInlineGas)
} }
function getUseNonceField (state) { export function getUseNonceField (state) {
return Boolean(state.metamask.useNonceField) return Boolean(state.metamask.useNonceField)
} }
function getCustomNonceValue (state) { export function getCustomNonceValue (state) {
return String(state.metamask.customNonceValue) return String(state.metamask.customNonceValue)
} }
function getPermissionsDescriptions (state) { export function getPermissionsDescriptions (state) {
return state.metamask.permissionsDescriptions return state.metamask.permissionsDescriptions
} }
function getPermissionsRequests (state) { export function getPermissionsRequests (state) {
return state.metamask.permissionsRequests return state.metamask.permissionsRequests
} }
function getDomainMetadata (state) { export function getDomainMetadata (state) {
return state.metamask.domainMetadata return state.metamask.domainMetadata
} }
function getActiveTab (state) { export function getActiveTab (state) {
return state.activeTab return state.activeTab
} }
function getMetaMetricState (state) { export function getMetaMetricState (state) {
return { return {
network: getCurrentNetworkId(state), network: getCurrentNetworkId(state),
activeCurrency: getSelectedAsset(state), activeCurrency: getSelectedAsset(state),
@ -413,14 +346,14 @@ function getMetaMetricState (state) {
} }
} }
function getRpcPrefsForCurrentProvider (state) { export function getRpcPrefsForCurrentProvider (state) {
const { frequentRpcListDetail, provider } = state.metamask const { frequentRpcListDetail, provider } = state.metamask
const selectRpcInfo = frequentRpcListDetail.find(rpcInfo => rpcInfo.rpcUrl === provider.rpcTarget) const selectRpcInfo = frequentRpcListDetail.find(rpcInfo => rpcInfo.rpcUrl === provider.rpcTarget)
const { rpcPrefs = {} } = selectRpcInfo || {} const { rpcPrefs = {} } = selectRpcInfo || {}
return rpcPrefs return rpcPrefs
} }
function getKnownMethodData (state, data) { export function getKnownMethodData (state, data) {
if (!data) { if (!data) {
return null return null
} }
@ -431,24 +364,24 @@ function getKnownMethodData (state, data) {
return knownMethodData && knownMethodData[fourBytePrefix] return knownMethodData && knownMethodData[fourBytePrefix]
} }
function getFeatureFlags (state) { export function getFeatureFlags (state) {
return state.metamask.featureFlags return state.metamask.featureFlags
} }
function getFirstPermissionRequest (state) { export function getFirstPermissionRequest (state) {
const requests = getPermissionsRequests(state) const requests = getPermissionsRequests(state)
return requests && requests[0] ? requests[0] : null return requests && requests[0] ? requests[0] : null
} }
function hasPermissionRequests (state) { export function hasPermissionRequests (state) {
return Boolean(getFirstPermissionRequest(state)) return Boolean(getFirstPermissionRequest(state))
} }
function getPermissionsDomains (state) { export function getPermissionsDomains (state) {
return state.metamask.domains return state.metamask.domains
} }
function getAddressConnectedDomainMap (state) { export function getAddressConnectedDomainMap (state) {
const { const {
domains, domains,
domainMetadata, domainMetadata,
@ -478,7 +411,7 @@ function getAddressConnectedDomainMap (state) {
return addressConnectedIconMap return addressConnectedIconMap
} }
function getDomainToConnectedAddressMap (state) { export function getDomainToConnectedAddressMap (state) {
const { domains = {} } = state.metamask const { domains = {} } = state.metamask
const domainToConnectedAddressMap = mapObjectValues(domains, (_, { permissions }) => { const domainToConnectedAddressMap = mapObjectValues(domains, (_, { permissions }) => {
@ -498,7 +431,7 @@ function getDomainToConnectedAddressMap (state) {
return domainToConnectedAddressMap return domainToConnectedAddressMap
} }
function getAddressConnectedToCurrentTab (state) { export function getAddressConnectedToCurrentTab (state) {
const domainToConnectedAddressMap = getDomainToConnectedAddressMap(state) const domainToConnectedAddressMap = getDomainToConnectedAddressMap(state)
const originOfCurrentTab = getOriginOfCurrentTab(state) const originOfCurrentTab = getOriginOfCurrentTab(state)
const addressesConnectedToCurrentTab = domainToConnectedAddressMap[originOfCurrentTab] const addressesConnectedToCurrentTab = domainToConnectedAddressMap[originOfCurrentTab]
@ -506,7 +439,7 @@ function getAddressConnectedToCurrentTab (state) {
return addressConnectedToCurrentTab return addressConnectedToCurrentTab
} }
function getRenderablePermissionsDomains (state) { export function getRenderablePermissionsDomains (state) {
const { const {
domains = {}, domains = {},
domainMetadata, domainMetadata,
@ -559,12 +492,12 @@ function getRenderablePermissionsDomains (state) {
return renderableDomains return renderableDomains
} }
function getOriginOfCurrentTab (state) { export function getOriginOfCurrentTab (state) {
const { activeTab } = state const { activeTab } = state
return activeTab && activeTab.url && getOriginFromUrl(activeTab.url) return activeTab && activeTab.url && getOriginFromUrl(activeTab.url)
} }
function getLastConnectedInfo (state) { export function getLastConnectedInfo (state) {
const { permissionsHistory = {} } = state.metamask const { permissionsHistory = {} } = state.metamask
const lastConnectedInfoData = Object.keys(permissionsHistory).reduce((acc, origin) => { const lastConnectedInfoData = Object.keys(permissionsHistory).reduce((acc, origin) => {
const ethAccountsHistory = JSON.parse(JSON.stringify(permissionsHistory[origin]['eth_accounts'])) const ethAccountsHistory = JSON.parse(JSON.stringify(permissionsHistory[origin]['eth_accounts']))

View File

@ -1,5 +1,5 @@
import assert from 'assert' import assert from 'assert'
import selectors from '../selectors.js' import * as selectors from '../selectors'
const { const {
getAddressBook, getAddressBook,
} = selectors } = selectors