From a9fc4f452f7adaac7c16806d0c917d2515dcf605 Mon Sep 17 00:00:00 2001 From: Dan Finlay Date: Fri, 6 May 2016 14:24:01 -0700 Subject: [PATCH 1/3] Move account panel style into reusable component The styles that defined the `account-panel` component now belong to the `panel` component, which is now used by the `account-panel` component for its styles. It accepts an optional `onClick` property that it will fire when clicked! Planning to use it for the tx-list. --- ui/app/account-detail.js | 3 +- ui/app/components/account-panel.js | 91 +++++++++------------------ ui/app/components/panel.js | 63 +++++++++++++++++++ ui/app/components/transaction-list.js | 4 +- 4 files changed, 98 insertions(+), 63 deletions(-) create mode 100644 ui/app/components/panel.js diff --git a/ui/app/account-detail.js b/ui/app/account-detail.js index 10c33c2bc..06ef6ff02 100644 --- a/ui/app/account-detail.js +++ b/ui/app/account-detail.js @@ -58,7 +58,8 @@ AccountDetailScreen.prototype.render = function() { showFullAddress: true, identity: identity, account: account, - }, []), + key: 'accountPanel' + }), h('div', { style: { diff --git a/ui/app/components/account-panel.js b/ui/app/components/account-panel.js index 25b5e5d24..c1450b516 100644 --- a/ui/app/components/account-panel.js +++ b/ui/app/components/account-panel.js @@ -6,6 +6,8 @@ const addressSummary = require('../util').addressSummary const formatBalance = require('../util').formatBalance const Identicon = require('identicon.js') +const Panel = require('./panel') + module.exports = AccountPanel @@ -23,49 +25,29 @@ AccountPanel.prototype.render = function() { var identicon = new Identicon(identity.address, 46).toString() var identiconSrc = `data:image/png;base64,${identicon}` - return ( - - h('.identity-panel.flex-row.flex-space-between'+(state.isSelected?'.selected':''), { - style: { - flex: '1 0 auto', + var panelOpts = { + key: `accountPanel${identity.address}`, + onClick: (event) => { + if (state.onShowDetail) { + state.onShowDetail(identity.address, event) + } + }, + identiconKey: identity.address, + identiconLabel: identity.name, + attributes: [ + { + key: 'ADDRESS', + value: addressSummary(identity.address) }, - onClick: (event) => state.onShowDetail(identity.address, event), - }, [ + balanceOrFaucetingIndication(account, isFauceting), + ] + } - // account identicon - h('.identicon-wrapper.flex-column.select-none', [ - h('img.identicon', { - src: identiconSrc, - style: { - border: 'none', - borderRadius: '20px', - } - }), - h('span.font-small', identity.name), - ]), + return h(Panel, panelOpts, + !state.onShowDetail ? null : h('.arrow-right.cursor-pointer', [ + h('i.fa.fa-chevron-right.fa-lg'), + ])) - // account address, balance - h('.identity-data.flex-column.flex-justify-center.flex-grow.select-none', [ - - h('.flex-row.flex-space-between', [ - h('label.font-small', 'ADDRESS'), - h('span.font-small', addressSummary(identity.address)), - ]), - - balanceOrFaucetingIndication(account, isFauceting), - - // outlet for inserting additional stuff - state.children, - - ]), - - // navigate to account detail - !state.onShowDetail ? null : - h('.arrow-right.cursor-pointer', [ - h('i.fa.fa-chevron-right.fa-lg'), - ]), - ]) - ) } function balanceOrFaucetingIndication(account, isFauceting) { @@ -73,27 +55,14 @@ function balanceOrFaucetingIndication(account, isFauceting) { // Temporarily deactivating isFauceting indication // because it shows fauceting for empty restored accounts. if (/*isFauceting*/ false) { - - return h('.flex-row.flex-space-between', [ - h('span.font-small', { - }, [ - 'Account is auto-funding,', - h('br'), - 'please wait.' - ]), - ]) - + return { + key: 'Account is auto-funding.', + value: 'Please wait.', + } } else { - - return h('.flex-row.flex-space-between', [ - h('label.font-small', 'BALANCE'), - h('span.font-small', { - style: { - overflowX: 'hidden', - maxWidth: '136px', - } - }, formatBalance(account.balance)), - ]) - + return { + key: 'BALANCE', + value: formatBalance(account.balance) + } } } diff --git a/ui/app/components/panel.js b/ui/app/components/panel.js new file mode 100644 index 000000000..25e6b7f0f --- /dev/null +++ b/ui/app/components/panel.js @@ -0,0 +1,63 @@ +const inherits = require('util').inherits +const ethUtil = require('ethereumjs-util') +const Component = require('react').Component +const h = require('react-hyperscript') +const Identicon = require('identicon.js') + +module.exports = Panel + + +inherits(Panel, Component) +function Panel() { + Component.call(this) +} + +Panel.prototype.render = function() { + var state = this.props + + var identity = state.identity || {} + var account = state.account || {} + var isFauceting = state.isFauceting + + var identicon = new Identicon(state.identiconKey, 46).toString() + var identiconSrc = `data:image/png;base64,${identicon}` + + return ( + h('.identity-panel.flex-row.flex-space-between', { + style: { + flex: '1 0 auto', + }, + onClick: state.onClick, + }, [ + + // account identicon + h('.identicon-wrapper.flex-column.select-none', [ + h('img.identicon', { + src: identiconSrc, + style: { + border: 'none', + borderRadius: '20px', + } + }), + h('span.font-small', state.identiconLabel), + ]), + + // account address, balance + h('.identity-data.flex-column.flex-justify-center.flex-grow.select-none', [ + + state.attributes.map((attr) => { + return h('.flex-row.flex-space-between', { + key: '' + Math.round(Math.random() * 1000000), + }, [ + h('label.font-small', attr.key), + h('span.font-small', attr.value), + ]) + }), + ]), + + // outlet for inserting additional stuff + state.children, + ]) + ) +} + diff --git a/ui/app/components/transaction-list.js b/ui/app/components/transaction-list.js index 115fd91f8..c5a86f082 100644 --- a/ui/app/components/transaction-list.js +++ b/ui/app/components/transaction-list.js @@ -16,7 +16,9 @@ module.exports = function(transactions, network) { h('div.font-small', {style: {display: 'inline'}}, 'Transactions'), transactions.map((transaction) => { - return h('.tx.flex-row.flex-space-around', [ + return h('.tx.flex-row.flex-space-around', { + key: `listed-tx-${transaction.hash}`, + }, [ h('a.font-small', { href: explorerLink(transaction.hash, parseInt(network)), From 356da540d12871bdb78f8dca8acdc6b9c5a523ec Mon Sep 17 00:00:00 2001 From: Dan Finlay Date: Fri, 6 May 2016 14:42:08 -0700 Subject: [PATCH 2/3] Style transaction list using new panel component --- CHANGELOG.md | 1 + ui/app/accounts.js | 2 +- ui/app/components/transaction-list.js | 70 ++++++++++++++++++--------- 3 files changed, 48 insertions(+), 25 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2df3947d3..b0df0be73 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,7 @@ - Restored back button to account detail view. - Show transaction list always, never collapsed. - Changing provider now reloads current Dapps +- Improved appearance of transaction list in account detail view. ## 1.7.0 2016-04-29 diff --git a/ui/app/accounts.js b/ui/app/accounts.js index 0cc72878c..16f37dc67 100644 --- a/ui/app/accounts.js +++ b/ui/app/accounts.js @@ -50,7 +50,7 @@ AccountsScreen.prototype.render = function() { * regardless of the current domain. */ h('.current-domain-panel.flex-center.font-small', [ - h('spam', 'Selected address is visible to all sites you visit.'), + h('span', 'Selected address is visible to all sites you visit.'), // h('span', state.currentDomain), ]), diff --git a/ui/app/components/transaction-list.js b/ui/app/components/transaction-list.js index c5a86f082..3e153aecf 100644 --- a/ui/app/components/transaction-list.js +++ b/ui/app/components/transaction-list.js @@ -2,32 +2,54 @@ const h = require('react-hyperscript') const formatBalance = require('../util').formatBalance const addressSummary = require('../util').addressSummary const explorerLink = require('../../lib/explorer-link') +const Panel = require('./panel') module.exports = function(transactions, network) { - return h('.tx-list', { - style: { - overflowY: 'auto', - height: '180px', - textAlign: 'center', + return h('section', [ + + h('.current-domain-panel.flex-center.font-small', [ + h('span', 'Transactions'), + ]), + + h('.tx-list', { + style: { + overflowY: 'auto', + height: '180px', + textAlign: 'center', + }, }, - }, - [ - h('div.font-small', {style: {display: 'inline'}}, 'Transactions'), + [ - transactions.map((transaction) => { - return h('.tx.flex-row.flex-space-around', { - key: `listed-tx-${transaction.hash}`, - }, [ - h('a.font-small', - { - href: explorerLink(transaction.hash, parseInt(network)), - target: '_blank', - }, - addressSummary(transaction.txParams.to)), - h('div.font-small', formatBalance(transaction.txParams.value)) - ]) - }) - ] - ) -} + transactions.map((transaction) => { + console.dir(transaction) + + var panelOpts = { + key: `tx-${transaction.hash}`, + identiconKey: transaction.txParams.to, + style: { + cursor: 'pointer', + }, + onClick: (event) => { + var url = explorerLink(transaction.hash, parseInt(network)) + chrome.tabs.create({ url }); + }, + attributes: [ + { + key: 'TO', + value: addressSummary(transaction.txParams.to), + }, + { + key: 'VALUE', + value: formatBalance(transaction.txParams.value), + }, + ] + } + + return h(Panel, panelOpts) + }) + ] + ) + + ]) + } From c30a67b2deb06c5d47990ccac74d9d55384bfe2e Mon Sep 17 00:00:00 2001 From: Dan Finlay Date: Fri, 6 May 2016 14:46:04 -0700 Subject: [PATCH 3/3] Restored signTx action --- ui/app/actions.js | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/ui/app/actions.js b/ui/app/actions.js index 9a8ba76d1..5e4a0d7da 100644 --- a/ui/app/actions.js +++ b/ui/app/actions.js @@ -61,6 +61,7 @@ var actions = { signMsg: signMsg, cancelMsg: cancelMsg, sendTx: sendTx, + signTx: signTx, cancelTx: cancelTx, completedTx: completedTx, txError: txError, @@ -165,6 +166,20 @@ function signMsg(msgData) { } } +function signTx(txData) { + return (dispatch) => { + dispatch(this.showLoadingIndication()) + + web3.eth.sendTransaction(txData, (err, data) => { + dispatch(this.hideLoadingIndication()) + + if (err) return dispatch(this.displayWarning(err.message)) + dispatch(this.hideWarning()) + dispatch(this.goHome()) + }) + } +} + function sendTx(txData) { return (dispatch) => { _accountManager.approveTransaction(txData.id, (err) => {