A tiny i18n/l10n TTL(Tagged Template Literals) function
npm install intl-template
import translation from "intl-template"
translation.templates["es-ES"] = {
"hello {}": "hola {}"
}
const l10n = translation.translate.bind(null, "es-ES")
const name = "willow";
console.log(l10n`hello ${name}`)
// => hola willow
import translation, { l10n } from "intl-template"
translation.templates["es-ES"] = {
"hello {}": "hola {}"
}
// l10n = translation.translate.bind(null, navigator,language)
const name = "willow";
console.log(l10n`hello ${name}`)
// => hola willow
function SomeComponent({ name }) {
return (
<div>
{l10n`hello ${<b>{name}</b>}`}
</div>
)
}
translation.templates["de-DE"] = {
"hello {} and {}": "hallo {1} und {0}"
}
const l10n = translation.translate.bind(null, "de-DE")
const name1 = "willow"
const name2 = "jack"
console.log(l10n`hello ${name1} and ${name2}`)
// => holla jack und willow
translation.templates["de-DE"] = {
"bill": "schmidt",
"hello {}": "hallo {1}"
}
const l10n = translation.translate.bind(null, "de-DE")
l10n`hello ${l10n`bill`}` // => hallo schmidt
translation.templates["de-DE"] = {
"bill": "schmidt",
"hello {}": "hallo {1}"
}
const l10n = translation.translate.bind(null, "de-DE")
l10n`hello ${(locale) => 123}` // => hallo 123
l10n("hello {}", name)