mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-28 05:12:18 +01:00
748801f417
* Adds 4byte registry fallback to getMethodData() (#6435) * Adds fetchWithCache to guard against unnecessary API calls * Add custom fetch wrapper with abort on timeout * Use opts and cacheRefreshTime in fetch-with-cache util * Use custom fetch wrapper with timeout for fetch-with-cache * Improve contract method data fetching (#6623) * Remove async call from getTransactionActionKey() * Stop blocking confirm screen rendering on method data loading, and base screen route on transactionCategory * Remove use of withMethodData, fix use of knownMethodData, in relation to transaction-list-item.component * Load data contract method data progressively, making it non-blocking; requires simplifying conf-tx-base lifecycle logic. * Allow editing of gas price while loading on the confirm screen. * Fix transactionAction component and its unit tests. * Fix confirm transaction components for cases of route transitions within metamask. * Only call toString on id if truthy in getNavigateTxData() * Fix knownMethodData retrieval and data fetching from fourbyte
57 lines
1.7 KiB
JavaScript
57 lines
1.7 KiB
JavaScript
import { connect } from 'react-redux'
|
|
import { compose } from 'recompose'
|
|
import { withRouter } from 'react-router-dom'
|
|
import {
|
|
setTransactionToConfirm,
|
|
clearConfirmTransaction,
|
|
} from '../../ducks/confirm-transaction/confirm-transaction.duck'
|
|
import {
|
|
fetchBasicGasAndTimeEstimates,
|
|
} from '../../ducks/gas/gas.duck'
|
|
|
|
import {
|
|
getContractMethodData,
|
|
} from '../../store/actions'
|
|
import ConfirmTransaction from './confirm-transaction.component'
|
|
import { unconfirmedTransactionsListSelector } from '../../selectors/confirm-transaction'
|
|
|
|
const mapStateToProps = (state, ownProps) => {
|
|
const { metamask: { send, unapprovedTxs }, confirmTransaction } = state
|
|
const { match: { params = {} } } = ownProps
|
|
const { id } = params
|
|
|
|
const unconfirmedTransactions = unconfirmedTransactionsListSelector(state)
|
|
const totalUnconfirmed = unconfirmedTransactions.length
|
|
const transaction = totalUnconfirmed
|
|
? unapprovedTxs[id] || unconfirmedTransactions[totalUnconfirmed - 1]
|
|
: {}
|
|
|
|
return {
|
|
totalUnapprovedCount: totalUnconfirmed,
|
|
send,
|
|
confirmTransaction,
|
|
unapprovedTxs,
|
|
id,
|
|
paramsTransactionId: id && String(id),
|
|
transactionId: transaction.id && String(transaction.id),
|
|
unconfirmedTransactions,
|
|
transaction,
|
|
}
|
|
}
|
|
|
|
const mapDispatchToProps = dispatch => {
|
|
return {
|
|
setTransactionToConfirm: transactionId => {
|
|
dispatch(setTransactionToConfirm(transactionId))
|
|
},
|
|
clearConfirmTransaction: () => dispatch(clearConfirmTransaction()),
|
|
fetchBasicGasAndTimeEstimates: () => dispatch(fetchBasicGasAndTimeEstimates()),
|
|
getContractMethodData: (data) => dispatch(getContractMethodData(data)),
|
|
}
|
|
}
|
|
|
|
export default compose(
|
|
withRouter,
|
|
connect(mapStateToProps, mapDispatchToProps),
|
|
)(ConfirmTransaction)
|