Package Exports
- flexible-currency-to-words
- flexible-currency-to-words/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (flexible-currency-to-words) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
๐ฌ Flexible Number to Words Converter
A CommonJS-compatible library to convert numbers to words for currencies. Supports both Indian and Western number systems with customizable currency units, decimal precision, and more. Handles extremely large numbers (up to 999,999,999,999,999,999) โ ideal for global finance apps.
โจ Features
- โ Converts numbers to words for any currency (e.g., Rupees, Dollars, Yen)
- โ
Supports Indian (
12,34,56,789
) and Western (123,456,789
) number formats - โ
Customizable options:
- Currency name (e.g.,
RUPEES
,DOLLARS
) - Fractional unit (e.g.,
PAISE
,CENTS
) - Decimal precision
- Output suffix (e.g.,
ONLY
)
- Currency name (e.g.,
- โ Handles numbers up to 999 QUADRILLION
- โ Graceful handling of invalid inputs
- โ 30+ unit tests for edge cases and consistency
- โ Fully Node.js/CommonJS compatible
๐ฆ Installation
npm install flexible-number-to-words
๐ Usage
js
Copy
Edit
const numberToWord = require('flexible-number-to-words');
// Default: Indian Rupees
console.log(numberToWord(254584.255));
// โ TWO LAKH FIFTY-FOUR THOUSAND FIVE HUNDRED EIGHTY-FOUR RUPEES AND TWENTY-SIX PAISE ONLY
// US Dollars with Western format
console.log(numberToWord(254584.255, {
currency: 'DOLLARS',
fractionalUnit: 'CENTS',
numberFormat: 'western'
}));
// โ TWO HUNDRED FIFTY-FOUR THOUSAND FIVE HUNDRED EIGHTY-FOUR DOLLARS AND TWENTY-SIX CENTS ONLY
// Large number example
console.log(numberToWord(1234567890123456));
// โ ONE ARAB TWENTY-THREE THOUSAND FOUR HUNDRED FIFTY-SIX CRORE SEVENTY-EIGHT LAKH NINETY THOUSAND ONE HUNDRED TWENTY-THREE RUPEES ONLY
// Custom decimal precision
console.log(numberToWord(123456.789, { decimalPlaces: 3 }));
// โ ONE LAKH TWENTY-THREE THOUSAND FOUR HUNDRED FIFTY-SIX RUPEES AND SEVEN HUNDRED EIGHTY-NINE PAISE ONLY
โ๏ธ Options
Option Type Description Default
currency string Major unit name (e.g., RUPEES, DOLLARS) RUPEES
fractionalUnit string Minor unit name (e.g., PAISE, CENTS) PAISE
decimalPlaces number Decimal precision to be converted to words 2
numberFormat string Format style: 'indian' or 'western' indian
separator string Thousands separator (e.g., ',', '.') ,
suffix string Text appended at the end of result ONLY
๐งช Testing
Run tests using Jest:
bash
Copy
Edit
npm test
Test suite includes:
Edge cases
Decimal rounding
Format validation
Singular/plural correctness
Input sanitization
๐ค Contributing
We welcome contributions! Please open an issue or submit a pull request via GitHub. Add tests for any new features or fixes.
๐ License
MIT License โ feel free to use, modify, and distribute.