A revolutionarily simple and easy to use i18n library easily integrable into any existing code base!
Kakyo is an extremely minimal, highly performant and fully tested internationalization (i18n for short) library following the KISS principle. Kakyo was developed with the intention of developers being able to easily integrate i18n into any existing code base without having to heavily refactor the project or even rewrite any single bit of code.
Internationalization is an important step in making an application as accessible as possible, and Kakyo is here to make it as painless and straightforward as humanly possible!
Installing Kakyo is as easy as running following command if you're using npm:
$ npm install kakyo
Alternatively you can also use yarn:
$ yarn add kakyo
Let's assume we have following folder structure:
kakyo-example
โ
โโโ node_modules/
โ โโโ kakyo/
โ
โโโ translations/
โ โโโ english.json
โ โโโ japanese.json
โ
โโโ index.js
Translations can be abstracted into their own respective translation files if so desired, however it's also possible to put every translation into the same file grouped by their locale to stop unnecessary clutter if the project is lightweight enough.
{
"en_US": {
"WELCOME_MESSAGE": "Welcome, #{username}#!",
"CURRENT_LEVEL": "Your level is #{level}#!"
}
}
{
"ja_JP": {
"WELCOME_MESSAGE": "ใใใใใ#{username}#๏ผ",
"CURRENT_LEVEL": "ใใชใใฎใฌใใซใฏ#{level}#ใงใ๏ผ"
}
}
Locales: Each language and thus its translations is grouped by its locale in the localisation files.
Response Keys: Each response must be keyed by a unique identifier which has to be identical amongst every language block.
Placeholders: Placeholders in translation files are initiated by an opening #{
, followed by a data property name that's wished to be used, followed by a closing }#
tag as shown above in the example files ( #{username}#
and #{level}#
).
const Kakyo = require('kakyo');
const translations = new Kakyo(__dirname + '/translations', { defaultLocale: 'en_US' });
console.log(
translations.get('WELCOME_MESSAGE', { username: 'John Doe' })
); /* โจ Welcome, John Doe! */
console.log(
translations.get('WELCOME_MESSAGE', { username: 'Satoshi' }, 'ja_JP')
); /* โจ ใใใใใSatoshi๏ผ */
console.log(
translations.get('CURRENT_LEVEL', { level: 45 })
); /* โจ Your level is 45! */
console.log(
translations.get('CURRENT_LEVEL', { level: 37 }, 'ja_JP')
); /* โจ ใใชใใฎใฌใใซใฏ37ใงใ๏ผ */
Instantiation: Kakyo only requires an absolute folder path to where the localisation files are stored.
Default Locale: Providing a default locale upon instantiating Kakyo is fully optional and can be omitted.
Changing Languages: Getting a response in a different language than what was set as the default is as simple as providing the desired locale as a function parameter!
Kakyo's API overview
const translations = new Kakyo(__dirname + '/translations', { defaultLocale: 'en_US' });
- folderPath
String
- An absolute file path of the directory that harbors all localisations. - options
Object
(optional) - Options for initializing Kakyo and overwriting its default behavior.- options.defaultLocale
String
(optional) - Set the default locale of this Kakyo instance.
- options.defaultLocale
const result = translations.get('WELCOME_MESSAGE', { username: 'Bob' }, 'ja_JP');
- key
String
- A response key identifier corresponding to responses saved in the localisation files. - data
Object
- An object containing the data which should be injected into the response template.- The data object properties MUST match the placeholder names used in the localisation files!
- locale
String
(optional) - A locale specifying which language the response text should be rendered in.- Only optional if a default locale has been set upon instantiating Kakyo!
Returns: String
- A fully rendered and ready to be used response string with the passed data values injected.
const currentDefaultLocale = translations.getDefaultLocale();
Returns: String
- The currently active default locale for this Kakyo instance.
translations.setDefaultLocale('ja_JP');
- locale
String
- The new default locale that is wished to be set.- Head's up! Locales are cAsE sEnSiTiVe!
Returns: void
- Setting a new default locale has no return value!
Classic syntax:
translations.reload().then((successful) => {
if (successful) {
/* โจ Reload was successful! */
}
}).catch((reloadingError) => {
/* โจ Reload wasn't successful! */
});
async / await syntax:
const successfullyReloaded = await translations.reload();
if (successfullyReloaded) {
/* โจ Reload was successful! */
}
Returns: Promise<Boolean>
- Resolves with a truthy promise upon successful reload!
This repository makes use of the MIT License and all of its correlating traits.
While it isn't mandatory, a small credit would be highly appreciated if this repository was to be reused!