to-words
Version:
Convert numbers to words in 132 locales with currency, ordinal, and BigInt support (TypeScript, ESM/CJS/UMD).
164 lines (163 loc) • 6.02 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.ToWords = void 0;
exports.toWords = toWords;
exports.toOrdinal = toOrdinal;
exports.toCurrency = toCurrency;
const ToWordsCore_js_1 = require("../ToWordsCore.js");
class Locale {
config = {
currency: {
name: 'Euro',
plural: 'Eurot',
singular: 'Euro',
symbol: '€',
fractionalUnit: {
name: 'Sent',
singular: 'Sent',
plural: 'Senti',
symbol: '¢',
},
},
texts: {
and: 'Ja',
minus: 'Miinus',
only: 'Ainult',
point: 'Koma',
},
numberWordsMapping: [
{ number: 1000000000000000, value: 'Kvadriljon' },
{ number: 1000000000000, value: 'Triljon' },
{ number: 1000000000, value: 'Miljard' },
{ number: 1000000, value: 'Miljon' },
{ number: 1000, value: 'Tuhat' },
{ number: 900, value: 'Üheksasada' },
{ number: 800, value: 'Kaheksasada' },
{ number: 700, value: 'Seitsesada' },
{ number: 600, value: 'Kuussada' },
{ number: 500, value: 'Viissada' },
{ number: 400, value: 'Nelisada' },
{ number: 300, value: 'Kolmsada' },
{ number: 200, value: 'Kakssada' },
{ number: 100, value: 'Sada' },
{ number: 90, value: 'Üheksakümmend' },
{ number: 80, value: 'Kaheksakümmend' },
{ number: 70, value: 'Seitsekümmend' },
{ number: 60, value: 'Kuuskümmend' },
{ number: 50, value: 'Viiskümmend' },
{ number: 40, value: 'Nelikümmend' },
{ number: 30, value: 'Kolmkümmend' },
{ number: 20, value: 'Kakskümmend' },
{ number: 19, value: 'Üheksateist' },
{ number: 18, value: 'Kaheksateist' },
{ number: 17, value: 'Seitseteist' },
{ number: 16, value: 'Kuusteist' },
{ number: 15, value: 'Viisteist' },
{ number: 14, value: 'Neliteist' },
{ number: 13, value: 'Kolmteist' },
{ number: 12, value: 'Kaksteist' },
{ number: 11, value: 'Üksteist' },
{ number: 10, value: 'Kümme' },
{ number: 9, value: 'Üheksa' },
{ number: 8, value: 'Kaheksa' },
{ number: 7, value: 'Seitse' },
{ number: 6, value: 'Kuus' },
{ number: 5, value: 'Viis' },
{ number: 4, value: 'Neli' },
{ number: 3, value: 'Kolm' },
{ number: 2, value: 'Kaks' },
{ number: 1, value: 'Üks' },
{ number: 0, value: 'Null' },
],
ordinalWordsMapping: [
{ number: 1000000, value: 'Miljones' },
{ number: 1000, value: 'Tuhandes' },
{ number: 100, value: 'Sajas' },
{ number: 90, value: 'Üheksakümnes' },
{ number: 80, value: 'Kaheksakümnes' },
{ number: 70, value: 'Seitsmekümnes' },
{ number: 60, value: 'Kuuekümnes' },
{ number: 50, value: 'Viiekümnes' },
{ number: 40, value: 'Neljakümnes' },
{ number: 30, value: 'Kolmekümnes' },
{ number: 20, value: 'Kahekümnes' },
{ number: 19, value: 'Üheksateistkümnes' },
{ number: 18, value: 'Kaheksateistkümnes' },
{ number: 17, value: 'Seitsmeteistkümnes' },
{ number: 16, value: 'Kuueteistkümnes' },
{ number: 15, value: 'Viieteistkümnes' },
{ number: 14, value: 'Neljateistkümnes' },
{ number: 13, value: 'Kolmeteistkümnes' },
{ number: 12, value: 'Kaheteistkümnes' },
{ number: 11, value: 'Üheteistkümnes' },
{ number: 10, value: 'Kümnes' },
{ number: 9, value: 'Üheksas' },
{ number: 8, value: 'Kaheksas' },
{ number: 7, value: 'Seitsmes' },
{ number: 6, value: 'Kuues' },
{ number: 5, value: 'Viies' },
{ number: 4, value: 'Neljas' },
{ number: 3, value: 'Kolmas' },
{ number: 2, value: 'Teine' },
{ number: 1, value: 'Esimene' },
],
ignoreOneForWords: [
'Sada',
'Kakssada',
'Kolmsada',
'Nelisada',
'Viissada',
'Kuussada',
'Seitsesada',
'Kaheksasada',
'Üheksasada',
],
exactWordsMapping: [
{
number: 100,
value: 'Ükssada',
},
],
pluralWords: ['Miljon', 'Miljard', 'Triljon', 'Kvadriljon'],
pluralMark: 'it',
onlyInFront: true,
};
}
exports.default = Locale;
/**
* ToWords class pre-configured for this locale.
* This is a lightweight version that only bundles this specific locale.
*
* @example
* import { ToWords } from 'to-words/ee-EE';
* const tw = new ToWords();
* tw.convert(1234);
*/
class ToWords extends ToWordsCore_js_1.ToWordsCore {
constructor(options = {}) {
super(options);
this.setLocale(Locale);
}
}
exports.ToWords = ToWords;
// Module-level singleton — reused across calls to avoid per-call instance creation
const instance = new ToWords();
/**
* Convert a number to words for this locale (functional style).
*/
function toWords(number, options) {
return instance.convert(number, options);
}
/**
* Convert a number to ordinal words for this locale (functional style).
*/
function toOrdinal(number, options) {
return instance.toOrdinal(number, options);
}
/**
* Convert a number to currency words for this locale (functional style).
* Shorthand for toWords(number, { currency: true, ...options }).
*/
function toCurrency(number, options) {
return instance.convert(number, { ...options, currency: true });
}