diff options
author | Dan Finlay <542863+danfinlay@users.noreply.github.com> | 2017-10-10 05:15:09 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-10 05:15:09 +0800 |
commit | f18615a82abafee1a648e8de6f60ecc54e1aabb4 (patch) | |
tree | 053914da168a427f0c644f81fa02119aca9ce5b5 /ui/app | |
parent | 7f70c866c3a74fadbc34f9b979902b89bba666f5 (diff) | |
parent | d82d9215fbe593293a6badc523218878cfb13dd2 (diff) | |
download | tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.tar tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.tar.gz tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.tar.bz2 tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.tar.lz tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.tar.xz tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.tar.zst tangerine-wallet-browser-f18615a82abafee1a648e8de6f60ecc54e1aabb4.zip |
Merge pull request #2296 from MetaMask/precision-fix
Fix precision to account for small wei increase.
Diffstat (limited to 'ui/app')
-rw-r--r-- | ui/app/components/bn-as-decimal-input.js | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/ui/app/components/bn-as-decimal-input.js b/ui/app/components/bn-as-decimal-input.js index f3ace4720..d84834d06 100644 --- a/ui/app/components/bn-as-decimal-input.js +++ b/ui/app/components/bn-as-decimal-input.js @@ -31,7 +31,7 @@ BnAsDecimalInput.prototype.render = function () { const suffix = props.suffix const style = props.style const valueString = value.toString(10) - const newValue = this.downsize(valueString, scale, precision) + const newValue = this.downsize(valueString, scale) return ( h('.flex-column', [ @@ -145,14 +145,17 @@ BnAsDecimalInput.prototype.constructWarning = function () { } -BnAsDecimalInput.prototype.downsize = function (number, scale, precision) { +BnAsDecimalInput.prototype.downsize = function (number, scale) { // if there is no scaling, simply return the number if (scale === 0) { return Number(number) } else { // if the scale is the same as the precision, account for this edge case. - var decimals = (scale === precision) ? -1 : scale - precision - return Number(number.slice(0, -scale) + '.' + number.slice(-scale, decimals)) + var adjustedNumber = number + while (adjustedNumber.length < scale) { + adjustedNumber = '0' + adjustedNumber + } + return Number(adjustedNumber.slice(0, -scale) + '.' + adjustedNumber.slice(-scale)) } } |