import React, { Component } from 'react'; import PropTypes from 'prop-types'; import Fuse from 'fuse.js'; import Identicon from '../../../../components/ui/identicon'; import Dialog from '../../../../components/ui/dialog'; import ContactList from '../../../../components/app/contact-list'; import RecipientGroup from '../../../../components/app/contact-list/recipient-group/recipient-group.component'; import { ellipsify } from '../../send.utils'; import Confusable from '../../../../components/ui/confusable'; import { Text } from '../../../../components/component-library'; import Box from '../../../../components/ui/box'; import { TextColor, TextVariant, } from '../../../../helpers/constants/design-system'; export default class AddRecipient extends Component { static propTypes = { userInput: PropTypes.string, ownedAccounts: PropTypes.array, addressBook: PropTypes.array, updateRecipient: PropTypes.func, domainResolution: PropTypes.string, domainError: PropTypes.string, domainWarning: PropTypes.string, addressBookEntryName: PropTypes.string, contacts: PropTypes.array, nonContacts: PropTypes.array, addHistoryEntry: PropTypes.func, recipient: PropTypes.shape({ address: PropTypes.string, nickname: PropTypes.string, error: PropTypes.string, warning: PropTypes.string, }), updateRecipientUserInput: PropTypes.func, }; constructor(props) { super(props); this.recentFuse = new Fuse(props.nonContacts, { shouldSort: true, threshold: 0.45, location: 0, distance: 100, maxPatternLength: 32, minMatchCharLength: 1, keys: [{ name: 'address', weight: 0.5 }], }); this.contactFuse = new Fuse(props.contacts, { shouldSort: true, threshold: 0.45, location: 0, distance: 100, maxPatternLength: 32, minMatchCharLength: 1, keys: [ { name: 'name', weight: 0.5 }, { name: 'address', weight: 0.5 }, ], }); } static contextTypes = { t: PropTypes.func, metricsEvent: PropTypes.func, }; selectRecipient = (address, nickname = '', type = 'user input') => { this.props.addHistoryEntry( `sendFlow - User clicked recipient from ${type}. address: ${address}, nickname ${nickname}`, ); this.props.updateRecipient({ address, nickname }); this.props.updateRecipientUserInput(address); }; searchForContacts = () => { const { userInput, contacts } = this.props; let _contacts = contacts; if (userInput) { this.contactFuse.setCollection(contacts); _contacts = this.contactFuse.search(userInput); } return _contacts; }; searchForRecents = () => { const { userInput, nonContacts } = this.props; let _nonContacts = nonContacts; if (userInput) { this.recentFuse.setCollection(nonContacts); _nonContacts = this.recentFuse.search(userInput); } return _nonContacts; }; render() { const { domainResolution, recipient, userInput, addressBookEntryName, ownedAccounts = [], } = this.props; let content; if (recipient.address) { content = this.renderExplicitAddress( recipient.address, recipient.nickname, 'validated user input', ); } else if (domainResolution && !recipient.error) { content = this.renderExplicitAddress( domainResolution, addressBookEntryName || userInput, 'ENS resolution', ); } return ( {ownedAccounts && ownedAccounts.length > 1 && !userInput && this.renderTransfer()} {this.renderDialogs()} {content || this.renderMain()} ); } renderExplicitAddress(address, name, type) { return (
this.selectRecipient(address, name, type)} >
{name ? : ellipsify(address)}
{name && (
{ellipsify(address)}
)}
); } renderTransfer() { const { t } = this.context; let { ownedAccounts } = this.props; const { userInput } = this.props; if (userInput) { ownedAccounts = ownedAccounts.filter( (item) => item.name.toLowerCase().indexOf(userInput.toLowerCase()) > -1 || item.address.toLowerCase().indexOf(userInput.toLowerCase()) > -1, ); } return ( <> {t('myAccounts')}
this.selectRecipient(address, name, 'my accounts') } />
); } renderMain() { const { t } = this.context; const { addressBook, userInput } = this.props; return (
{addressBook.length && userInput > 0 ? ( {t('contacts')} ) : null} { this.selectRecipient( address, name, `${name ? 'contact' : 'recent'} list`, ); }} />
); } renderDialogs() { const { domainError, recipient, domainWarning } = this.props; const { t } = this.context; if (domainError || (recipient.error && recipient.error !== 'required')) { return ( {t(domainError ?? recipient.error)} ); } else if (domainWarning || recipient.warning) { return ( {t(domainWarning ?? recipient.warning)} ); } return null; } }