aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/components
diff options
context:
space:
mode:
authorDan Finlay <542863+danfinlay@users.noreply.github.com>2018-09-18 01:25:12 +0800
committerGitHub <noreply@github.com>2018-09-18 01:25:12 +0800
commit934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc (patch)
treef00bcf3853428dc785024bc07564d1f02c061c3e /ui/app/components
parent2f14f978e390772e78e4cc2ee7a778c9106d053c (diff)
parentdaca7f9b41d784a44c7f5469b8f9b710e0a08e4b (diff)
downloadtangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.tar
tangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.tar.gz
tangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.tar.bz2
tangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.tar.lz
tangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.tar.xz
tangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.tar.zst
tangerine-wallet-browser-934b10307c97793dd2cf5ac10c3b4d96fb8cbfcc.zip
Merge pull request #4803 from MetaMask/eip-712
EIP-712: Sign typed data
Diffstat (limited to 'ui/app/components')
-rw-r--r--ui/app/components/signature-request.js30
1 files changed, 23 insertions, 7 deletions
diff --git a/ui/app/components/signature-request.js b/ui/app/components/signature-request.js
index 2bfa350d3..5b0c7684a 100644
--- a/ui/app/components/signature-request.js
+++ b/ui/app/components/signature-request.js
@@ -8,6 +8,7 @@ const ethUtil = require('ethereumjs-util')
const classnames = require('classnames')
const { compose } = require('recompose')
const { withRouter } = require('react-router-dom')
+const { ObjectInspector } = require('react-inspector')
const AccountDropdownMini = require('./dropdowns/account-dropdown-mini')
@@ -169,12 +170,29 @@ SignatureRequest.prototype.msgHexToText = function (hex) {
}
}
+// eslint-disable-next-line react/display-name
+SignatureRequest.prototype.renderTypedDataV3 = function (data) {
+ const { domain, message } = JSON.parse(data)
+ return [
+ h('div.request-signature__typed-container', [
+ domain ? h('div', [
+ h('h1', 'Domain'),
+ h(ObjectInspector, { data: domain, expandLevel: 1, name: 'domain' }),
+ ]) : '',
+ message ? h('div', [
+ h('h1', 'Message'),
+ h(ObjectInspector, { data: message, expandLevel: 1, name: 'message' }),
+ ]) : '',
+ ]),
+ ]
+}
+
SignatureRequest.prototype.renderBody = function () {
let rows
let notice = this.context.t('youSign') + ':'
const { txData } = this.props
- const { type, msgParams: { data } } = txData
+ const { type, msgParams: { data, version } } = txData
if (type === 'personal_sign') {
rows = [{ name: this.context.t('message'), value: this.msgHexToText(data) }]
@@ -205,9 +223,9 @@ SignatureRequest.prototype.renderBody = function () {
}),
}, [notice]),
- h('div.request-signature__rows', [
-
- ...rows.map(({ name, value }) => {
+ h('div.request-signature__rows', type === 'eth_signTypedData' && version === 'V3' ?
+ this.renderTypedDataV3(data) :
+ rows.map(({ name, value }) => {
if (typeof value === 'boolean') {
value = value.toString()
}
@@ -216,9 +234,7 @@ SignatureRequest.prototype.renderBody = function () {
h('div.request-signature__row-value', value),
])
}),
-
- ]),
-
+ ),
])
}