import { connect } from 'react-redux'; import { withRouter } from 'react-router-dom'; import { compose } from 'redux'; import { getGasLimit, getGasPrice, getGasTotal, getPrimaryCurrency, getSendToken, getSendTokenContract, getSendAmount, getSendEditingTransactionId, getSendFromObject, getSendTo, getSendToNickname, getTokenBalance, getQrCodeData, getSelectedAddress, getAddressBook, getSendTokenAddress, isCustomPriceExcessive, getCurrentChainId, } from '../../selectors'; import { showQrScanner, qrCodeDetected } from '../../store/actions'; import { resetSendState, updateSendErrors, updateSendTo, updateSendTokenBalance, updateGasData, setGasTotal, updateSendEnsResolution, updateSendEnsResolutionError, } from '../../ducks/send/send.duck'; import { fetchBasicGasEstimates } from '../../ducks/gas/gas.duck'; import { getBlockGasLimit, getConversionRate, getSendHexDataFeatureFlagState, getTokens, } from '../../ducks/metamask/metamask'; import { isValidDomainName } from '../../helpers/utils/util'; import { calcGasTotal } from './send.utils'; import SendEther from './send.component'; function mapStateToProps(state) { const editingTransactionId = getSendEditingTransactionId(state); return { addressBook: getAddressBook(state), amount: getSendAmount(state), blockGasLimit: getBlockGasLimit(state), conversionRate: getConversionRate(state), editingTransactionId, from: getSendFromObject(state), gasLimit: getGasLimit(state), gasPrice: getGasPrice(state), gasTotal: getGasTotal(state), chainId: getCurrentChainId(state), primaryCurrency: getPrimaryCurrency(state), qrCodeData: getQrCodeData(state), selectedAddress: getSelectedAddress(state), sendToken: getSendToken(state), showHexData: getSendHexDataFeatureFlagState(state), to: getSendTo(state), toNickname: getSendToNickname(state), tokens: getTokens(state), tokenBalance: getTokenBalance(state), tokenContract: getSendTokenContract(state), sendTokenAddress: getSendTokenAddress(state), gasIsExcessive: isCustomPriceExcessive(state, true), }; } function mapDispatchToProps(dispatch) { return { updateAndSetGasLimit: ({ blockGasLimit, editingTransactionId, gasLimit, gasPrice, selectedAddress, sendToken, to, value, data, }) => { editingTransactionId ? dispatch(setGasTotal(calcGasTotal(gasLimit, gasPrice))) : dispatch( updateGasData({ gasPrice, selectedAddress, sendToken, blockGasLimit, to, value, data, }), ); }, updateSendTokenBalance: ({ sendToken, tokenContract, address }) => { dispatch( updateSendTokenBalance({ sendToken, tokenContract, address, }), ); }, updateSendErrors: (newError) => dispatch(updateSendErrors(newError)), resetSendState: () => dispatch(resetSendState()), scanQrCode: () => dispatch(showQrScanner()), qrCodeDetected: (data) => dispatch(qrCodeDetected(data)), updateSendTo: (to, nickname) => dispatch(updateSendTo(to, nickname)), fetchBasicGasEstimates: () => dispatch(fetchBasicGasEstimates()), updateSendEnsResolution: (ensResolution) => dispatch(updateSendEnsResolution(ensResolution)), updateSendEnsResolutionError: (message) => dispatch(updateSendEnsResolutionError(message)), updateToNicknameIfNecessary: (to, toNickname, addressBook) => { if (isValidDomainName(toNickname)) { const addressBookEntry = addressBook.find(({ address }) => to === address) || {}; if (!addressBookEntry.name !== toNickname) { dispatch(updateSendTo(to, addressBookEntry.name || '')); } } }, }; } export default compose( withRouter, connect(mapStateToProps, mapDispatchToProps), )(SendEther);