2018-04-27 21:03:00 +02:00
|
|
|
import { connect } from 'react-redux'
|
|
|
|
import SendEther from './send.component'
|
|
|
|
import { withRouter } from 'react-router-dom'
|
|
|
|
import { compose } from 'recompose'
|
2019-04-11 19:50:03 +02:00
|
|
|
const {
|
|
|
|
getSelectedAddress,
|
2019-04-17 21:15:13 +02:00
|
|
|
} = require('../../selectors/selectors')
|
2019-04-11 19:50:03 +02:00
|
|
|
|
2018-04-27 21:03:00 +02:00
|
|
|
import {
|
|
|
|
getAmountConversionRate,
|
2018-05-22 17:16:53 +02:00
|
|
|
getBlockGasLimit,
|
2018-04-27 21:03:00 +02:00
|
|
|
getConversionRate,
|
|
|
|
getCurrentNetwork,
|
|
|
|
getGasLimit,
|
|
|
|
getGasPrice,
|
|
|
|
getGasTotal,
|
|
|
|
getPrimaryCurrency,
|
2018-05-22 10:10:06 +02:00
|
|
|
getRecentBlocks,
|
2018-04-27 21:03:00 +02:00
|
|
|
getSelectedToken,
|
|
|
|
getSelectedTokenContract,
|
|
|
|
getSelectedTokenToFiatRate,
|
|
|
|
getSendAmount,
|
|
|
|
getSendEditingTransactionId,
|
2018-08-16 09:43:13 +02:00
|
|
|
getSendHexDataFeatureFlagState,
|
2018-04-27 21:03:00 +02:00
|
|
|
getSendFromObject,
|
2018-06-18 18:37:01 +02:00
|
|
|
getSendTo,
|
2019-07-31 21:56:44 +02:00
|
|
|
getSendToNickname,
|
2018-04-27 21:03:00 +02:00
|
|
|
getTokenBalance,
|
2018-07-25 02:32:20 +02:00
|
|
|
getQrCodeData,
|
2019-07-31 21:56:44 +02:00
|
|
|
getSendEnsResolution,
|
|
|
|
getSendEnsResolutionError,
|
2018-04-27 21:03:00 +02:00
|
|
|
} from './send.selectors'
|
2019-07-31 21:56:44 +02:00
|
|
|
import {
|
|
|
|
getAddressBook,
|
|
|
|
} from '../../selectors/selectors'
|
|
|
|
import { getTokens } from './send-content/add-recipient/add-recipient.selectors'
|
2018-04-27 21:03:00 +02:00
|
|
|
import {
|
2018-07-24 04:10:57 +02:00
|
|
|
updateSendTo,
|
2018-04-27 21:03:00 +02:00
|
|
|
updateSendTokenBalance,
|
2018-05-20 02:37:44 +02:00
|
|
|
updateGasData,
|
2018-04-27 21:03:00 +02:00
|
|
|
setGasTotal,
|
2018-08-01 00:30:40 +02:00
|
|
|
showQrScanner,
|
2018-08-04 02:11:46 +02:00
|
|
|
qrCodeDetected,
|
2019-07-31 21:56:44 +02:00
|
|
|
updateSendEnsResolution,
|
|
|
|
updateSendEnsResolutionError,
|
2019-04-17 21:15:13 +02:00
|
|
|
} from '../../store/actions'
|
2018-04-27 21:03:00 +02:00
|
|
|
import {
|
2018-06-29 19:19:40 +02:00
|
|
|
resetSendState,
|
2018-04-27 21:03:00 +02:00
|
|
|
updateSendErrors,
|
2019-04-17 21:15:13 +02:00
|
|
|
} from '../../ducks/send/send.duck'
|
2018-08-16 14:28:27 +02:00
|
|
|
import {
|
2018-10-09 18:35:54 +02:00
|
|
|
fetchBasicGasEstimates,
|
2019-04-17 21:15:13 +02:00
|
|
|
} from '../../ducks/gas/gas.duck'
|
2018-04-27 21:03:00 +02:00
|
|
|
import {
|
|
|
|
calcGasTotal,
|
|
|
|
} from './send.utils.js'
|
2019-07-31 21:56:44 +02:00
|
|
|
import {
|
|
|
|
isValidENSAddress,
|
|
|
|
} from '../../helpers/utils/util'
|
2018-04-27 21:03:00 +02:00
|
|
|
|
2018-08-01 00:30:40 +02:00
|
|
|
import {
|
|
|
|
SEND_ROUTE,
|
2019-04-17 21:15:13 +02:00
|
|
|
} from '../../helpers/constants/routes'
|
2018-08-01 00:30:40 +02:00
|
|
|
|
2018-04-27 21:03:00 +02:00
|
|
|
module.exports = compose(
|
|
|
|
withRouter,
|
|
|
|
connect(mapStateToProps, mapDispatchToProps)
|
|
|
|
)(SendEther)
|
|
|
|
|
|
|
|
function mapStateToProps (state) {
|
|
|
|
return {
|
|
|
|
amount: getSendAmount(state),
|
|
|
|
amountConversionRate: getAmountConversionRate(state),
|
2018-05-22 17:16:53 +02:00
|
|
|
blockGasLimit: getBlockGasLimit(state),
|
2018-04-27 21:03:00 +02:00
|
|
|
conversionRate: getConversionRate(state),
|
|
|
|
editingTransactionId: getSendEditingTransactionId(state),
|
|
|
|
from: getSendFromObject(state),
|
|
|
|
gasLimit: getGasLimit(state),
|
|
|
|
gasPrice: getGasPrice(state),
|
|
|
|
gasTotal: getGasTotal(state),
|
|
|
|
network: getCurrentNetwork(state),
|
|
|
|
primaryCurrency: getPrimaryCurrency(state),
|
2018-05-22 10:10:06 +02:00
|
|
|
recentBlocks: getRecentBlocks(state),
|
2018-04-27 21:03:00 +02:00
|
|
|
selectedAddress: getSelectedAddress(state),
|
|
|
|
selectedToken: getSelectedToken(state),
|
2018-08-16 09:43:13 +02:00
|
|
|
showHexData: getSendHexDataFeatureFlagState(state),
|
2019-07-31 21:56:44 +02:00
|
|
|
ensResolution: getSendEnsResolution(state),
|
|
|
|
ensResolutionError: getSendEnsResolutionError(state),
|
2018-06-18 18:37:01 +02:00
|
|
|
to: getSendTo(state),
|
2019-07-31 21:56:44 +02:00
|
|
|
toNickname: getSendToNickname(state),
|
|
|
|
tokens: getTokens(state),
|
2018-04-27 21:03:00 +02:00
|
|
|
tokenBalance: getTokenBalance(state),
|
|
|
|
tokenContract: getSelectedTokenContract(state),
|
|
|
|
tokenToFiatRate: getSelectedTokenToFiatRate(state),
|
2018-07-25 02:32:20 +02:00
|
|
|
qrCodeData: getQrCodeData(state),
|
2019-07-31 21:56:44 +02:00
|
|
|
addressBook: getAddressBook(state),
|
2018-04-27 21:03:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function mapDispatchToProps (dispatch) {
|
|
|
|
return {
|
2018-09-13 10:47:05 +02:00
|
|
|
updateAndSetGasLimit: ({
|
2018-05-22 17:16:53 +02:00
|
|
|
blockGasLimit,
|
2018-04-27 21:03:00 +02:00
|
|
|
editingTransactionId,
|
|
|
|
gasLimit,
|
|
|
|
gasPrice,
|
2018-05-22 10:10:06 +02:00
|
|
|
recentBlocks,
|
2018-04-27 21:03:00 +02:00
|
|
|
selectedAddress,
|
|
|
|
selectedToken,
|
2018-05-23 18:43:25 +02:00
|
|
|
to,
|
|
|
|
value,
|
2018-09-27 15:46:24 +02:00
|
|
|
data,
|
2018-04-27 21:03:00 +02:00
|
|
|
}) => {
|
|
|
|
!editingTransactionId
|
2018-09-13 10:47:05 +02:00
|
|
|
? dispatch(updateGasData({ gasPrice, recentBlocks, selectedAddress, selectedToken, blockGasLimit, to, value, data }))
|
2018-04-27 21:03:00 +02:00
|
|
|
: dispatch(setGasTotal(calcGasTotal(gasLimit, gasPrice)))
|
|
|
|
},
|
|
|
|
updateSendTokenBalance: ({ selectedToken, tokenContract, address }) => {
|
|
|
|
dispatch(updateSendTokenBalance({
|
|
|
|
selectedToken,
|
|
|
|
tokenContract,
|
|
|
|
address,
|
|
|
|
}))
|
|
|
|
},
|
|
|
|
updateSendErrors: newError => dispatch(updateSendErrors(newError)),
|
2018-06-29 19:19:40 +02:00
|
|
|
resetSendState: () => dispatch(resetSendState()),
|
2018-08-01 00:30:40 +02:00
|
|
|
scanQrCode: () => dispatch(showQrScanner(SEND_ROUTE)),
|
2018-08-04 02:11:46 +02:00
|
|
|
qrCodeDetected: (data) => dispatch(qrCodeDetected(data)),
|
2018-07-24 04:10:57 +02:00
|
|
|
updateSendTo: (to, nickname) => dispatch(updateSendTo(to, nickname)),
|
2018-10-09 18:35:54 +02:00
|
|
|
fetchBasicGasEstimates: () => dispatch(fetchBasicGasEstimates()),
|
2019-07-31 21:56:44 +02:00
|
|
|
updateSendEnsResolution: (ensResolution) => dispatch(updateSendEnsResolution(ensResolution)),
|
|
|
|
updateSendEnsResolutionError: (message) => dispatch(updateSendEnsResolutionError(message)),
|
|
|
|
updateToNicknameIfNecessary: (to, toNickname, addressBook) => {
|
|
|
|
if (isValidENSAddress(toNickname)) {
|
|
|
|
const addressBookEntry = addressBook.find(({ address}) => to === address) || {}
|
|
|
|
if (!addressBookEntry.name !== toNickname) {
|
|
|
|
dispatch(updateSendTo(to, addressBookEntry.name || ''))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2018-04-27 21:03:00 +02:00
|
|
|
}
|
|
|
|
}
|