Skip to content

Commit

Permalink
Merge pull request #52609 from thelullabyy/fix/49929-52342-distance-r…
Browse files Browse the repository at this point in the history
…ates

fix: apply 4 decimal values for distance rate display
  • Loading branch information
puneetlath authored Nov 26, 2024
2 parents b550938 + c8d7c57 commit 6e1855e
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 10 deletions.
1 change: 1 addition & 0 deletions src/CONST.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5949,6 +5949,7 @@ const CONST = {

MAX_TAX_RATE_INTEGER_PLACES: 4,
MAX_TAX_RATE_DECIMAL_PLACES: 4,
MIN_TAX_RATE_DECIMAL_PLACES: 2,

DOWNLOADS_PATH: '/Downloads',
DOWNLOADS_TIMEOUT: 5000,
Expand Down
3 changes: 2 additions & 1 deletion src/libs/CurrencyUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,8 @@ function convertAmountToDisplayString(amount = 0, currency: string = CONST.CURRE
return NumberFormatUtils.format(BaseLocaleListener.getPreferredLocale(), convertedAmount, {
style: 'currency',
currency,
minimumFractionDigits: CONST.MAX_TAX_RATE_DECIMAL_PLACES,
minimumFractionDigits: CONST.MIN_TAX_RATE_DECIMAL_PLACES,
maximumFractionDigits: CONST.MAX_TAX_RATE_DECIMAL_PLACES,
});
}

Expand Down
12 changes: 6 additions & 6 deletions src/libs/PolicyUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,8 @@ function getNumericValue(value: number | string, toLocaleDigit: (arg: string) =>
if (Number.isNaN(numValue)) {
return NaN;
}
return numValue.toFixed(CONST.CUSTOM_UNITS.RATE_DECIMALS);
// Rounding to 4 decimal places
return parseFloat(numValue.toFixed(CONST.MAX_TAX_RATE_DECIMAL_PLACES));
}

/**
Expand Down Expand Up @@ -170,11 +171,10 @@ function getRateDisplayValue(value: number, toLocaleDigit: (arg: string) => stri
}

if (withDecimals) {
const decimalPart = numValue.toString().split('.').at(1);
if (decimalPart) {
const fixedDecimalPoints = decimalPart.length > 2 && !decimalPart.endsWith('0') ? 3 : 2;
return Number(numValue).toFixed(fixedDecimalPoints).toString().replace('.', toLocaleDigit('.'));
}
const decimalPart = numValue.toString().split('.').at(1) ?? '';
// Set the fraction digits to be between 2 and 4 (OD Behavior)
const fractionDigits = Math.min(Math.max(decimalPart.length, CONST.MIN_TAX_RATE_DECIMAL_PLACES), CONST.MAX_TAX_RATE_DECIMAL_PLACES);
return Number(numValue).toFixed(fractionDigits).toString().replace('.', toLocaleDigit('.'));
}

return numValue.toString().replace('.', toLocaleDigit('.')).substring(0, value.toString().length);
Expand Down
42 changes: 39 additions & 3 deletions tests/unit/PolicyUtilsTest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,50 @@ describe('PolicyUtils', () => {
expect(rate).toEqual('10.50');
});

it('should return non-integer value with 4 decimals as is', () => {
const rate = PolicyUtils.getRateDisplayValue(10.5312, toLocaleDigitMock, true);
expect(rate).toEqual('10.5312');
});

it('should return non-integer value with 3 decimals as is', () => {
const rate = PolicyUtils.getRateDisplayValue(10.531, toLocaleDigitMock, true);
expect(rate).toEqual('10.531');
});

it('should return non-integer value with 3+ decimals cut to 3', () => {
const rate = PolicyUtils.getRateDisplayValue(10.531345, toLocaleDigitMock, true);
expect(rate).toEqual('10.531');
it('should return non-integer value with 4+ decimals cut to 4', () => {
const rate = PolicyUtils.getRateDisplayValue(10.53135, toLocaleDigitMock, true);
expect(rate).toEqual('10.5313');
});
});
});

describe('getUnitRateValue', () => {
it('should return an empty string for NaN', () => {
const rate = PolicyUtils.getUnitRateValue(toLocaleDigitMock, {rate: 'invalid' as unknown as number});
expect(rate).toEqual('');
});

describe('withDecimals = false', () => {
it('should return value divisible by 100 with no decimal places', () => {
const rate = PolicyUtils.getUnitRateValue(toLocaleDigitMock, {rate: 100});
expect(rate).toEqual('1');
});

it('should return non-integer value as is divided by 100', () => {
const rate = PolicyUtils.getUnitRateValue(toLocaleDigitMock, {rate: 11.11});
expect(rate).toEqual('0.1111');
});
});

describe('withDecimals = true', () => {
it('should return value divisible by 100 with 2 decimal places', () => {
const rate = PolicyUtils.getUnitRateValue(toLocaleDigitMock, {rate: 100}, true);
expect(rate).toEqual('1.00');
});

it('should return non-integer value as is divided by 100', () => {
const rate = PolicyUtils.getUnitRateValue(toLocaleDigitMock, {rate: 11.11}, true);
expect(rate).toEqual('0.1111');
});
});
});
Expand Down

0 comments on commit 6e1855e

Please sign in to comment.