33 lines
917 B
TypeScript
33 lines
917 B
TypeScript
import { getLocale } from 'next-intl/server';
|
||
import { LanguageRoutes } from '../config/i18n/types';
|
||
|
||
/**
|
||
* Format price. With label.
|
||
* @param amount Price
|
||
* @param withLabel Show label. Default false
|
||
* @returns string. Ex. X XXX XXX sum
|
||
*/
|
||
const formatPrice = async (amount: number | string, withLabel?: boolean) => {
|
||
const locale = (await getLocale()) as LanguageRoutes;
|
||
const label = withLabel
|
||
? locale === LanguageRoutes.RU
|
||
? ' сум'
|
||
: locale === LanguageRoutes.KI
|
||
? ' сўм'
|
||
: ' so‘m'
|
||
: '';
|
||
const parts = String(amount).split('.');
|
||
const dollars = parts[0];
|
||
const cents = parts.length > 1 ? parts[1] : '00';
|
||
|
||
const formattedDollars = dollars.replace(/\B(?=(\d{3})+(?!\d))/g, ' ');
|
||
|
||
if (String(amount).length === 0) {
|
||
return formattedDollars + '.' + cents + label;
|
||
} else {
|
||
return formattedDollars + label;
|
||
}
|
||
};
|
||
|
||
export default formatPrice;
|