mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Merge branch 'master' into ConfirmationStyle
This commit is contained in:
commit
a02f43fb7f
@ -77,14 +77,13 @@ module.exports = class MetamaskController {
|
|||||||
|
|
||||||
// handle rpc request
|
// handle rpc request
|
||||||
this.provider.sendAsync(request, function onPayloadHandled (err, response) {
|
this.provider.sendAsync(request, function onPayloadHandled (err, response) {
|
||||||
if (err) {
|
logger(err, request, response)
|
||||||
return logger(err)
|
if (response) {
|
||||||
}
|
try {
|
||||||
logger(null, request, response)
|
stream.write(response)
|
||||||
try {
|
} catch (err) {
|
||||||
stream.write(response)
|
logger(err)
|
||||||
} catch (err) {
|
}
|
||||||
logger(err)
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -148,22 +148,35 @@ describe('util', function() {
|
|||||||
|
|
||||||
it('when given nothing', function() {
|
it('when given nothing', function() {
|
||||||
var result = util.formatBalance()
|
var result = util.formatBalance()
|
||||||
|
assert.equal(result, 'None', 'should return "None"')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return eth as string followed by ETH', function() {
|
||||||
|
var input = new ethUtil.BN(ethInWei, 10).toJSON()
|
||||||
|
var result = util.formatBalance(input, 4)
|
||||||
|
assert.equal(result, '1.0000 ETH')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('should return eth as string followed by ETH', function() {
|
||||||
|
var input = new ethUtil.BN(ethInWei, 10).div(new ethUtil.BN('2', 10)).toJSON()
|
||||||
|
var result = util.formatBalance(input, 3)
|
||||||
|
assert.equal(result, '0.500 ETH')
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should display specified decimal points', function() {
|
it('should display specified decimal points', function() {
|
||||||
var input = "0x128dfa6a90b28000"
|
var input = "0x128dfa6a90b28000"
|
||||||
var result = util.formatBalance(input, 2)
|
var result = util.formatBalance(input, 2)
|
||||||
assert.equal(result.formatted, '1.33 ETH')
|
assert.equal(result, '1.33 ETH')
|
||||||
})
|
})
|
||||||
it('should default to 2 decimal points', function() {
|
it('should default to 3 decimal points', function() {
|
||||||
var input = "0x128dfa6a90b28000"
|
var input = "0x128dfa6a90b28000"
|
||||||
var result = util.formatBalance(input)
|
var result = util.formatBalance(input)
|
||||||
assert.equal(result.formatted, '1.33 ETH')
|
assert.equal(result, '1.337 ETH')
|
||||||
})
|
})
|
||||||
it('should show 2 significant digits for tiny balances', function() {
|
it('should show 2 significant digits for tiny balances', function() {
|
||||||
var input = "0x1230fa6a90b28"
|
var input = "0x1230fa6a90b28"
|
||||||
var result = util.formatBalance(input)
|
var result = util.formatBalance(input)
|
||||||
assert.equal(result.formatted, '0.00032 ETH')
|
assert.equal(result, '0.00032 ETH')
|
||||||
})
|
})
|
||||||
|
|
||||||
})
|
})
|
||||||
|
@ -2,7 +2,6 @@ const Component = require('react').Component
|
|||||||
const h = require('react-hyperscript')
|
const h = require('react-hyperscript')
|
||||||
const inherits = require('util').inherits
|
const inherits = require('util').inherits
|
||||||
const formatBalance = require('../util').formatBalance
|
const formatBalance = require('../util').formatBalance
|
||||||
const Tooltip = require('./tooltip')
|
|
||||||
|
|
||||||
module.exports = EthBalanceComponent
|
module.exports = EthBalanceComponent
|
||||||
|
|
||||||
@ -32,32 +31,28 @@ EthBalanceComponent.prototype.render = function () {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
EthBalanceComponent.prototype.renderBalance = function (value) {
|
EthBalanceComponent.prototype.renderBalance = function (value) {
|
||||||
|
|
||||||
if (value === 'None') return value
|
if (value === 'None') return value
|
||||||
|
|
||||||
var balance = value.formatted.split(' ')[0]
|
var balance = value.split(' ')[0]
|
||||||
var label = value.formatted.split(' ')[1]
|
var label = value.split(' ')[1]
|
||||||
|
|
||||||
return (
|
return (
|
||||||
h(Tooltip, {
|
h('.flex-column', {
|
||||||
title: value.balance,
|
style: {
|
||||||
position: 'bottom',
|
alignItems: 'flex-end',
|
||||||
|
lineHeight: '13px',
|
||||||
|
fontFamily: 'Montserrat Thin',
|
||||||
|
textRendering: 'geometricPrecision',
|
||||||
|
},
|
||||||
}, [
|
}, [
|
||||||
h('.flex-column', {
|
h('div', balance),
|
||||||
|
h('div', {
|
||||||
style: {
|
style: {
|
||||||
alignItems: 'flex-end',
|
color: ' #AEAEAE',
|
||||||
lineHeight: '13px',
|
fontSize: '12px',
|
||||||
fontFamily: 'Montserrat Light',
|
|
||||||
textRendering: 'geometricPrecision',
|
|
||||||
},
|
},
|
||||||
}, [
|
}, label),
|
||||||
h('div', balance),
|
|
||||||
h('div', {
|
|
||||||
style: {
|
|
||||||
color: ' #AEAEAE',
|
|
||||||
fontSize: '12px',
|
|
||||||
},
|
|
||||||
}, label),
|
|
||||||
]),
|
|
||||||
])
|
])
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -110,29 +110,22 @@ function formatBalance (balance, decimalsToKeep) {
|
|||||||
var parsed = parseBalance(balance)
|
var parsed = parseBalance(balance)
|
||||||
var beforeDecimal = parsed[0]
|
var beforeDecimal = parsed[0]
|
||||||
var afterDecimal = parsed[1]
|
var afterDecimal = parsed[1]
|
||||||
var formatted, formattedBalance
|
var formatted = 'None'
|
||||||
|
if (decimalsToKeep === undefined) {
|
||||||
if (beforeDecimal === '0') {
|
if (beforeDecimal === '0') {
|
||||||
if (afterDecimal !== '0') {
|
if (afterDecimal !== '0') {
|
||||||
var sigFigs = afterDecimal.match(/^0*(.{2})/) // default: grabs 2 most significant digits
|
var sigFigs = afterDecimal.match(/^0*(.{2})/) // default: grabs 2 most significant digits
|
||||||
if (sigFigs) { afterDecimal = sigFigs[0] }
|
if (sigFigs) { afterDecimal = sigFigs[0] }
|
||||||
formattedBalance = afterDecimal.substr(0, 5) === '00000' ? '<0.00001' : `0.${afterDecimal.slice(0, 6)}`
|
formatted = '0.' + afterDecimal + ' ETH'
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
formatted = beforeDecimal + '.' + afterDecimal.slice(0, 3) + ' ETH'
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
formattedBalance = `${beforeDecimal}.${afterDecimal.slice(0, 2)}`
|
afterDecimal += Array(decimalsToKeep).join('0')
|
||||||
|
formatted = beforeDecimal + '.' + afterDecimal.slice(0, decimalsToKeep) + ' ETH'
|
||||||
}
|
}
|
||||||
if (decimalsToKeep) {
|
return formatted
|
||||||
formattedBalance = `${beforeDecimal}.${afterDecimal.slice(0, decimalsToKeep)}`
|
|
||||||
}
|
|
||||||
|
|
||||||
formatted = `${formattedBalance} ETH`
|
|
||||||
|
|
||||||
if (formattedBalance === '0.0' || formattedBalance === undefined) {
|
|
||||||
formatted = 'None'
|
|
||||||
formattedBalance = 'None'
|
|
||||||
}
|
|
||||||
|
|
||||||
return {formattedBalance, balance: parsed.join('.'), formatted}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function dataSize (data) {
|
function dataSize (data) {
|
||||||
|
Loading…
Reference in New Issue
Block a user