Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
fast-plural-rules
Advanced tools
Evaluates locale-specific plural rules to identify the right plural form for a cardinal number, which represents an item count.
Evaluates locale-specific plural rules to identify the right plural form for a cardinal number, which represents an item count. Internationalization libraries can utilize it to choose the right localized string.
zero
, one
, two
, few
, many
and other
) and includes declarations for TypeScript.If you are looking for a library compiling and executing the declarative CLDR plural rules, see plural-rules. Generated programmatically for better reliability, but a little bigger and slower.
const { getPluralFormForCardinalByLocale } = require('fast-plural-rules')
// Returns index of the plural form for the specified locale and cardinal.
getPluralFormForCardinalByLocale('en', 1) // Returns 0; "1 file"
getPluralFormForCardinalByLocale('en', 2) // Returns 1; "2 files"
getPluralFormForCardinalByLocale('en', 5) // Returns 1; "5 files"
getPluralFormForCardinalByLocale('cs', 1) // Returns 0; "1 soubor"
getPluralFormForCardinalByLocale('cs', 2) // Returns 1; "2 soubory"
getPluralFormForCardinalByLocale('cs', 5) // Returns 2; "5 souborů"
// Returns a localized message for the specified locale and cardinal.
localizeMessage('en', 'fileCount', 3) // Returns "3 files"
localizeMessage('cs', 'fileCount', 3) // Returns "3 soubory"
// Returns a localized message for the specified locale and cardinal.
function localizeMessage (locale, messageKey, cardinal) {
const pluralForm = getPluralFormForCardinalByLocale(locale, cardinal)
const messageFormat = messages[locale][messageKey][pluralForm]
return messageFormat.replace('{0}', cardinal)
}
// A language pack with a testing message.
const messages = {
en: {
fileCount: [
"{0} file", // 0 - singular
"{0} files" // 1 - plural
],
}
cs: {
fileCount: [
"{0} soubor", // 0 - singular
"{0} soubory", // 1 - plural for 2-4 items
"{0} souborů" // 2 - plural for 5+ items
]
}
}
There is another full example using plural form names instead of numeric indexes like this:
// Localized messages organized by locales and message keys.
const messages = {
en: {
fileCount: {
one: '{0} file', // singular
other: '{0} files' // plural
}
},
cs: {
fileCount: {
one: '{0} soubor', // singular
few: '{0} soubory', // plural for 2-4 items
other: '{0} souborů' // plural for 5 and more items
}
}
}
This module can be installed in your project using NPM or Yarn. Make sure, that you use Node.js version 6 or newer.
$ npm i fast-plural-rules --save
$ yarn add fast-plural-rules
Functions are exposed as named exports, for example:
const { getPluralFormForCardinalByLocale } = require('fast-plural-rules')
You can read more about the module loading in other environments, like with ES6 or in web browsers. Usage scenarios demonstrate applications of this library in typical real-world situations. Design concepts explain the approach to the correct internationalization of messages with cardinals taken by this library. Translators will read about plural rules for supported languages to be able to write the right plural forms to language packs. Finally, the API reference lists all functions with a description of their functionality.
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.
Copyright (c) 2018-2019 Ferdinand Prantl
Licensed under the MIT license.
1.0.0 (2019-07-31)
If you write language packs for these language groups:
Move the string for the plural form for zero to the beginning of the string array.
The Semitic (Arabic) plural rules still put the zero plural form as the last one as the Mozilla's original does.
FAQs
Evaluates locale-specific plural rules to identify the right plural form for a cardinal number, which represents an item count.
The npm package fast-plural-rules receives a total of 3,334 weekly downloads. As such, fast-plural-rules popularity was classified as popular.
We found that fast-plural-rules demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.