From f909ddc69954093ea631ea0d54bde6e4639b1a58 Mon Sep 17 00:00:00 2001 From: Mikhail Mikheev Date: Tue, 1 Oct 2019 19:58:21 +0400 Subject: [PATCH] formatAmount wip, use Intl.Numberformat --- src/logic/tokens/utils/formatAmount.js | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/src/logic/tokens/utils/formatAmount.js b/src/logic/tokens/utils/formatAmount.js index b1bd325b..460e12e7 100644 --- a/src/logic/tokens/utils/formatAmount.js +++ b/src/logic/tokens/utils/formatAmount.js @@ -1,10 +1,25 @@ // @flow -// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat + +// Locale is an empty array because we want it to use user's locale +const lt1000Formatter = new Intl.NumberFormat([], { maximumFractionDigits: 5 }) +const lt10000Formatter = new Intl.NumberFormat([], { maximumFractionDigits: 4 }) +const lt100000Formatter = new Intl.NumberFormat([], { maximumFractionDigits: 3 }) +const lt1000000Formatter = new Intl.NumberFormat([], { maximumFractionDigits: 2 }) +const lt10000000Formatter = new Intl.NumberFormat([], { maximumFractionDigits: 1 }) + export const formatAmount = (number: string | number) => { let numberFloat = parseFloat(number) - if (numberFloat < 999.999999) { - numberFloat = numberFloat.toFixed(5).toLocaleString() + if (numberFloat < 1000) { + numberFloat = lt1000Formatter.format(numberFloat) + } else if (numberFloat < 10000) { + numberFloat = lt10000Formatter.format(numberFloat) + } else if (numberFloat < 100000) { + numberFloat = lt100000Formatter.format(numberFloat) + } else if (numberFloat < 1000000) { + numberFloat = lt1000000Formatter.format(numberFloat) + } else if (numberFloat < 10000000) { + numberFloat = lt10000000Formatter.format(numberFloat) } return numberFloat