Skip to content

Commit

Permalink
fix(formatters): decimalSeparator & thousandSeparator work tgt
Browse files Browse the repository at this point in the history
- when using both together, 1 was cancelling the other. To fix this, I rewrote the code use text split by the decimal and then recombining them as a new text with necessary thousand & decimal separators
  • Loading branch information
ghiscoding-SE committed Mar 17, 2020
1 parent 3e28d5d commit 62de7c2
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 4 deletions.
21 changes: 21 additions & 0 deletions packages/common/src/services/__tests__/utilities.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -331,6 +331,17 @@ describe('Service/Utilies', () => {
expect(output2).toBe('12,345,678');
});

it('should return a string without decimals but using dot (.) as thousand separator when these arguments are null or undefined and the input provided is an integer', () => {
const input = 12345678;
const decimalSeparator = ',';
const thousandSeparator = '.';
const output1 = formatNumber(input, null, null, false, '', '', decimalSeparator, thousandSeparator);
const output2 = formatNumber(input, undefined, undefined, false, '', '', decimalSeparator, thousandSeparator);

expect(output1).toBe('12.345.678');
expect(output2).toBe('12.345.678');
});

it('should return a formatted string wrapped in parentheses when the input number is negative and the displayNegativeNumberWithParentheses argument is enabled', () => {
const input = -123;
const displayNegativeNumberWithParentheses = true;
Expand Down Expand Up @@ -372,6 +383,16 @@ describe('Service/Utilies', () => {
expect(output).toBe('-$12,345,678.00');
});

it('should return a formatted currency string and thousand separator using dot (.) and decimal using comma (,) when those are provided', () => {
const input = -12345678.32;
const displayNegativeNumberWithParentheses = false;
const currencyPrefix = '$';
const decimalSeparator = ',';
const thousandSeparator = '.';
const output = formatNumber(input, 2, 2, displayNegativeNumberWithParentheses, currencyPrefix, '', decimalSeparator, thousandSeparator);
expect(output).toBe('-$12.345.678,32');
});

it('should return a formatted currency string with symbol prefix/suffix wrapped in parentheses when the input number is negative, when all necessary arguments are filled', () => {
const input = -1234;
const displayNegativeNumberWithParentheses = true;
Expand Down
20 changes: 16 additions & 4 deletions packages/common/src/services/utilities.ts
Original file line number Diff line number Diff line change
Expand Up @@ -102,17 +102,29 @@ export function decimalFormatted(input: number | string, minDecimal?: number, ma
amount += '0';
}

const decimalSplit = amount.split('.');
let integerNumber;
let decimalNumber;

// do we want to display our number with a custom separator in each thousand position
if (thousandSeparator) {
amount = thousandSeparatorFormatted(amount, thousandSeparator) || '';
integerNumber = decimalSplit.length >= 1 ? thousandSeparatorFormatted(decimalSplit[0], thousandSeparator) : undefined;
} else {
integerNumber = decimalSplit.length >= 1 ? decimalSplit[0] : amount;
}

// when using a separator that is not a dot, replace it with the new separator
if (decimalSeparator !== '.') {
amount = amount.replace('.', decimalSeparator);
if (decimalSplit.length > 1) {
decimalNumber = decimalSplit[1];
}

return amount;
let output = '';
if (integerNumber !== undefined && decimalNumber !== undefined) {
output = `${integerNumber}${decimalSeparator}${decimalNumber}`;
} else {
output = integerNumber;
}
return output;
}

/**
Expand Down

0 comments on commit 62de7c2

Please sign in to comment.