Skip to content

🙊 A template literal translation utility

License

Notifications You must be signed in to change notification settings

ubermanu/transplate

Repository files navigation

transplate

This package provides a simple translation system for JavaScript applications.

Features

  • A single function (template literal) to translate strings
  • A lexicon that defaults to English
  • Supports placeholder formats
  • Supports pluralization, according to the CLDR rules
  • Supports contextualization

Installation

npm install transplate

Usage

import { Dictionary, registerDictionary, t } from 'transplate'

const dict = new Dictionary('jp')

dict.addTranslation({
  id: 'Hello, %s!',
  strings: ['こんにちは、%s!'],
})

registerDictionary(dict)

const username = 'John'
t`Hello, ${username}!` // Hello, John!

setLocale('jp')
t`Hello, ${username}!` // こんにちは、John!

API

t

Translates a string in the defined locale, using a template literal.

{
  "id": "Hello!",
  "strings": ["Salut!"]
}
import { t } from 'transplate'

t`Hello!` // Salut!

Supports placeholders, if defined in the translation:

{
  "id": "Hello, %s!",
  "strings": ["Salut, %s!"]
}
import { t } from 'transplate'

const name = 'John'
t`Hello, ${name}!` // Salut, John!

Supports pluralization:

{
  "id": "You have %d new message.",
  "plural_id": "You have %d new messages.",
  "strings": [
    "Vous avez %d nouveau message.",
    "Vous avez %d nouveaux messages."
  ]
}
import { t } from 'transplate'

t`You have ${1} new message.` // Vous avez 1 nouveau message.
t`You have ${877} new message.` // Vous avez 877 nouveaux messages.

Supports contextualization:

{
  "id": "Welcome Mr %s",
  "strings": ["Bienvenue M. %s"],
  "context": "m"
}
{
  "id": "Welcome Mr %s",
  "strings": ["Bienvenue Mme %s"],
  "context": "f"
}
import { t } from 'transplate'

const data = {
  firstname: 'Sarah',
  gender: 'f',
}

// Generates a new translation function with the given context
const tx = t.context(data.gender)

tx`Welcome Mr ${data.firstname}` // Bienvenue Mme Sarah

getLocale

Returns the current locale. Defaults to en.

import { getLocale } from 'transplate'

getLocale() // en

setLocale

Sets the current locale in the ISO 639-1 format.

import { setLocale } from 'transplate'

setLocale('fr')

detectLocale

Detects the current locale, using the current process' environment variables or the browser's navigator.language.

import { detectLocale } from 'transplate'

detectLocale() // the locale has been set to `xx`

registerDictionary

Registers a dictionary for a given language, in the global lexicon.

import { registerDictionary, Dictionary } from 'transplate'

const dict = new Dictionary('fr')

dict.addTranslation({
  id: 'Hello!',
  strings: ['Salut!'],
})

registerDictionary(dict)