aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkumavis <aaron@kumavis.me>2016-06-25 03:48:52 +0800
committerkumavis <aaron@kumavis.me>2016-06-25 03:48:52 +0800
commiteb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee (patch)
tree4b188f7b5e915e037f62f4c9511bfe4a913eb3e8
parentd3a8f3eebe3605dc4a0895dcbc9ecbc75301fcb5 (diff)
downloadtangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.tar
tangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.tar.gz
tangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.tar.bz2
tangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.tar.lz
tangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.tar.xz
tangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.tar.zst
tangerine-wallet-browser-eb1b9d027fad9cf63bf5fea75b4e40b17d0cd7ee.zip
breakout pending-tx-details
-rw-r--r--app/scripts/lib/notifications.js7
-rw-r--r--ui/app/components/account-panel.js2
-rw-r--r--ui/app/components/pending-tx-details.js65
-rw-r--r--ui/app/components/pending-tx.js34
-rw-r--r--ui/app/conf-tx.js4
5 files changed, 77 insertions, 35 deletions
diff --git a/app/scripts/lib/notifications.js b/app/scripts/lib/notifications.js
index 5762fd26b..ce39c93ac 100644
--- a/app/scripts/lib/notifications.js
+++ b/app/scripts/lib/notifications.js
@@ -4,7 +4,7 @@ const findDOMNode = require('react-dom').findDOMNode
const render = require('react-dom').render
const h = require('react-hyperscript')
const uiUtils = require('../../../ui/app/util')
-const renderPendingTx = require('../../../ui/app/components/pending-tx').prototype.renderGeneric
+const renderPendingTx = require('../../../ui/app/components/pending-tx-details').prototype.renderGeneric
const MetaMaskUiCss = require('../../../ui/css')
var notificationHandlers = {}
@@ -64,7 +64,7 @@ function createTxNotification (opts) {
var id = createId()
chrome.notifications.create(id, {
type: 'image',
- // requireInteraction: true,
+ requireInteraction: true,
iconUrl: '/images/icon-128.png',
imageUrl: imageUrl,
title: opts.title,
@@ -113,8 +113,7 @@ function createMsgNotification (opts) {
function renderTransactionNotificationSVG(opts, cb){
var state = {
- nonInteractive: true,
- inlineIdenticons: true,
+ imageifyIdenticons: false,
txData: {
txParams: opts.txParams,
time: (new Date()).getTime(),
diff --git a/ui/app/components/account-panel.js b/ui/app/components/account-panel.js
index b98a8cb45..c69557d62 100644
--- a/ui/app/components/account-panel.js
+++ b/ui/app/components/account-panel.js
@@ -46,7 +46,7 @@ AccountPanel.prototype.render = function () {
h('.identicon-wrapper.flex-column.select-none', [
h(Identicon, {
address: panelState.identiconKey,
- imageify: !state.inlineIdenticons,
+ imageify: state.imageifyIdenticons,
}),
h('span.font-small', panelState.identiconLabel),
]),
diff --git a/ui/app/components/pending-tx-details.js b/ui/app/components/pending-tx-details.js
new file mode 100644
index 000000000..2ba613f20
--- /dev/null
+++ b/ui/app/components/pending-tx-details.js
@@ -0,0 +1,65 @@
+const Component = require('react').Component
+const h = require('react-hyperscript')
+const inherits = require('util').inherits
+
+const AccountPanel = require('./account-panel')
+const addressSummary = require('../util').addressSummary
+const readableDate = require('../util').readableDate
+const formatBalance = require('../util').formatBalance
+
+module.exports = PendingTxDetails
+
+inherits(PendingTxDetails, Component)
+function PendingTxDetails () {
+ Component.call(this)
+}
+
+PendingTxDetails.prototype.render = function () {
+ var state = this.props
+ return this.renderGeneric(h, state)
+}
+
+PendingTxDetails.prototype.renderGeneric = function (h, state) {
+ var txData = state.txData
+
+ var txParams = txData.txParams || {}
+ var address = txParams.from || state.selectedAddress
+ var identity = state.identities[address] || { address: address }
+ var account = state.accounts[address] || { address: address }
+
+ return (
+
+ h('div', [
+
+ // account that will sign
+ h(AccountPanel, {
+ showFullAddress: true,
+ identity: identity,
+ account: account,
+ imageifyIdenticons: state.imageifyIdenticons,
+ }),
+
+ // tx data
+ h('.tx-data.flex-column.flex-justify-center.flex-grow.select-none', [
+
+ h('.flex-row.flex-space-between', [
+ h('label.font-small', 'TO ADDRESS'),
+ h('span.font-small', addressSummary(txParams.to)),
+ ]),
+
+ h('.flex-row.flex-space-between', [
+ h('label.font-small', 'DATE'),
+ h('span.font-small', readableDate(txData.time)),
+ ]),
+
+ h('.flex-row.flex-space-between', [
+ h('label.font-small', 'AMOUNT'),
+ h('span.font-small', formatBalance(txParams.value)),
+ ]),
+ ]),
+
+ ])
+
+ )
+
+}
diff --git a/ui/app/components/pending-tx.js b/ui/app/components/pending-tx.js
index 484046827..f889877c9 100644
--- a/ui/app/components/pending-tx.js
+++ b/ui/app/components/pending-tx.js
@@ -3,6 +3,7 @@ const h = require('react-hyperscript')
const inherits = require('util').inherits
const AccountPanel = require('./account-panel')
+const PendingTxDetails = require('./pending-tx-details')
const addressSummary = require('../util').addressSummary
const readableDate = require('../util').readableDate
const formatBalance = require('../util').formatBalance
@@ -29,10 +30,11 @@ PendingTx.prototype.renderGeneric = function (h, state) {
return (
- h('.transaction', {
+ h('div', {
key: txData.id,
}, [
+ // header
h('h3', {
style: {
fontWeight: 'bold',
@@ -40,35 +42,11 @@ PendingTx.prototype.renderGeneric = function (h, state) {
},
}, 'Submit Transaction'),
- // account that will sign
- h(AccountPanel, {
- showFullAddress: true,
- identity: identity,
- account: account,
- inlineIdenticons: state.inlineIdenticons,
- }),
-
- // tx data
- h('.tx-data.flex-column.flex-justify-center.flex-grow.select-none', [
-
- h('.flex-row.flex-space-between', [
- h('label.font-small', 'TO ADDRESS'),
- h('span.font-small', addressSummary(txParams.to)),
- ]),
-
- h('.flex-row.flex-space-between', [
- h('label.font-small', 'DATE'),
- h('span.font-small', readableDate(txData.time)),
- ]),
-
- h('.flex-row.flex-space-between', [
- h('label.font-small', 'AMOUNT'),
- h('span.font-small', formatBalance(txParams.value)),
- ]),
- ]),
+ // tx info
+ h(PendingTxDetails, state),
// send + cancel
- state.nonInteractive ? null : actionButtons(state),
+ actionButtons(state),
])
diff --git a/ui/app/conf-tx.js b/ui/app/conf-tx.js
index 5c80939b9..8455826b8 100644
--- a/ui/app/conf-tx.js
+++ b/ui/app/conf-tx.js
@@ -6,7 +6,7 @@ const connect = require('react-redux').connect
const actions = require('./actions')
const txHelper = require('../lib/tx-helper')
-const ConfirmTx = require('./components/pending-tx')
+const PendingTx = require('./components/pending-tx')
const PendingMsg = require('./components/pending-msg')
module.exports = connect(mapStateToProps)(ConfirmTxScreen)
@@ -101,7 +101,7 @@ ConfirmTxScreen.prototype.render = function () {
function currentTxView (opts) {
if ('txParams' in opts.txData) {
// This is a pending transaction
- return h(ConfirmTx, opts)
+ return h(PendingTx, opts)
} else if ('msgParams' in opts.txData) {
// This is a pending message to sign
return h(PendingMsg, opts)