1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Make transaction list into actual React Component

This commit is contained in:
Dan Finlay 2016-05-25 17:18:04 -07:00
parent 5669f44300
commit 45ae2a0be3
2 changed files with 71 additions and 56 deletions

View File

@ -7,10 +7,11 @@ const copyToClipboard = require('copy-to-clipboard')
const actions = require('./actions') const actions = require('./actions')
const addressSummary = require('./util').addressSummary const addressSummary = require('./util').addressSummary
const ReactCSSTransitionGroup = require('react-addons-css-transition-group') const ReactCSSTransitionGroup = require('react-addons-css-transition-group')
const valuesFor = require('./util').valuesFor
const Identicon = require('./components/identicon') const Identicon = require('./components/identicon')
const EtherBalance = require('./components/eth-balance') const EtherBalance = require('./components/eth-balance')
const transactionList = require('./components/transaction-list') const TransactionList = require('./components/transaction-list')
const ExportAccountView = require('./components/account-export') const ExportAccountView = require('./components/account-export')
const ethUtil = require('ethereumjs-util') const ethUtil = require('ethereumjs-util')
const EditableLabel = require('./components/editable-label') const EditableLabel = require('./components/editable-label')
@ -24,7 +25,9 @@ function mapStateToProps(state) {
address: state.metamask.selectedAccount, address: state.metamask.selectedAccount,
accountDetail: state.appState.accountDetail, accountDetail: state.appState.accountDetail,
transactions: state.metamask.transactions, transactions: state.metamask.transactions,
networkVersion: state.metamask.network, network: state.metamask.network,
unconfTxs: valuesFor(state.metamask.unconfTxs),
unconfMsgs: valuesFor(state.metamask.unconfMsgs),
} }
} }
@ -139,7 +142,7 @@ AccountDetailScreen.prototype.render = function() {
}), }),
h('button', { h('button', {
onClick: () => this.props.dispatch(actions.showSendPage()), onClick: () => props.dispatch(actions.showSendPage()),
style: { style: {
margin: 10, margin: 10,
}, },
@ -183,18 +186,22 @@ AccountDetailScreen.prototype.subview = function() {
} }
AccountDetailScreen.prototype.transactionList = function() { AccountDetailScreen.prototype.transactionList = function() {
var state = this.props const { transactions, unconfTxs, unconfMsgs, address, network } = this.props
var transactions = state.transactions
var txsToRender = transactions var txsToRender = transactions
// only transactions that are from the current address // only transactions that are from the current address
.filter(tx => tx.txParams.from === state.address) .filter(tx => tx.txParams.from === address)
// only transactions that are on the current network // only transactions that are on the current network
.filter(tx => tx.txParams.metamaskNetworkId === state.networkVersion) .filter(tx => tx.txParams.metamaskNetworkId === network)
// sort by recency // sort by recency
.sort((a, b) => b.time - a.time) .sort((a, b) => b.time - a.time)
return transactionList(txsToRender, state.networkVersion) return h(TransactionList, {
txsToRender,
network,
unconfTxs,
unconfMsgs,
})
} }
AccountDetailScreen.prototype.navigateToAccounts = function(event){ AccountDetailScreen.prototype.navigateToAccounts = function(event){

View File

@ -1,4 +1,7 @@
const Component = require('react').Component
const h = require('react-hyperscript') const h = require('react-hyperscript')
const inherits = require('util').inherits
const vreme = new (require('vreme')) const vreme = new (require('vreme'))
const formatBalance = require('../util').formatBalance const formatBalance = require('../util').formatBalance
const addressSummary = require('../util').addressSummary const addressSummary = require('../util').addressSummary
@ -7,8 +10,18 @@ const Panel = require('./panel')
const Identicon = require('./identicon') const Identicon = require('./identicon')
const EtherBalance = require('./eth-balance') const EtherBalance = require('./eth-balance')
module.exports = TransactionList
inherits(TransactionList, Component)
function TransactionList() {
Component.call(this)
}
TransactionList.prototype.render = function() {
const { txsToRender, network, unconfTxs, unconfMsgs } = this.props
const transactions = txsToRender.concat(unconfTxs).concat(unconfMsgs)
module.exports = function(transactions, network) {
return ( return (
h('section.transaction-list', [ h('section.transaction-list', [
@ -49,16 +62,13 @@ module.exports = function(transactions, network) {
height: '100%', height: '100%',
}, },
}, 'No transaction history...')] }, 'No transaction history...')]
)) ))
]) ])
) )
}
function renderTransaction(transaction, i){ function renderTransaction(transaction, i){
var txParams = transaction.txParams var txParams = transaction.txParams
var date = formatDate(transaction.time) var date = formatDate(transaction.time)
@ -96,7 +106,6 @@ module.exports = function(transactions, network) {
) )
} }
}
function recipientField(txParams, transaction) { function recipientField(txParams, transaction) {
if (txParams.to) { if (txParams.to) {
@ -121,7 +130,6 @@ function recipientField(txParams, transaction) {
'Contract Published', 'Contract Published',
failIfFailed(transaction), failIfFailed(transaction),
]) ])
} }
} }