import PropTypes from 'prop-types'; import React, { PureComponent } from 'react'; import { ICON_NAMES } from '../../component-library/icon/deprecated'; import { MenuItem } from '../../ui/menu'; import ConnectedAccountsListItem from './connected-accounts-list-item'; import ConnectedAccountsListOptions from './connected-accounts-list-options'; export default class ConnectedAccountsList extends PureComponent { static contextTypes = { t: PropTypes.func.isRequired, }; static defaultProps = { accountToConnect: null, }; static propTypes = { accountToConnect: PropTypes.shape({ address: PropTypes.string.isRequired, name: PropTypes.string.isRequired, }), connectedAccounts: PropTypes.arrayOf( PropTypes.shape({ address: PropTypes.string.isRequired, name: PropTypes.string.isRequired, lastActive: PropTypes.number, }), ).isRequired, connectAccount: PropTypes.func.isRequired, selectedAddress: PropTypes.string.isRequired, removePermittedAccount: PropTypes.func, setSelectedAddress: PropTypes.func.isRequired, shouldRenderListOptions: (props, propName, componentName) => { if (typeof props[propName] !== 'boolean') { return new Error( `Warning: Failed prop type: '${propName}' of component '${componentName}' must be a boolean. Received: ${typeof props[ propName ]}`, ); } else if (props[propName] && !props.removePermittedAccount) { return new Error( `Warning: Failed prop type: '${propName}' of component '${componentName}' requires prop 'removePermittedAccount'.`, ); } return undefined; }, }; state = { accountWithOptionsShown: null, }; disconnectAccount = () => { this.hideAccountOptions(); this.props.removePermittedAccount(this.state.accountWithOptionsShown); }; switchAccount = (address) => { this.hideAccountOptions(); this.props.setSelectedAddress(address); }; hideAccountOptions = () => { this.setState({ accountWithOptionsShown: null }); }; showAccountOptions = (address) => { this.setState({ accountWithOptionsShown: address }); }; renderUnconnectedAccount() { const { accountToConnect, connectAccount } = this.props; const { t } = this.context; if (!accountToConnect) { return null; } const { address, name } = accountToConnect; return ( connectAccount(accountToConnect.address)} > {t('connect')} } /> ); } renderListItemOptions(address) { const { accountWithOptionsShown } = this.state; const { t } = this.context; return ( {t('disconnectThisAccount')} ); } renderListItemAction(address) { const { t } = this.context; return ( this.switchAccount(address)} > {t('switchToThisAccount')} ); } render() { const { connectedAccounts, selectedAddress, shouldRenderListOptions } = this.props; const { t } = this.context; return ( <>
{this.renderUnconnectedAccount()} {connectedAccounts.map(({ address, name }, index) => { return ( ); })}
); } }