Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
@codegouvfr/eleventy-plugin-i18n
Advanced tools
Eleventy plugin to assist with dictionary translations
Eleventy plugin to assist with internationalization and dictionary translations.
What's in the box? A contextually-aware i18n
filter, with smarts and dynamic string interpolation.
Available on npm.
npm install eleventy-plugin-i18n --save
Dive in to see how the plugin is used in a multilingual Eleventy site:
We'll be writing up a tutorial to provide a guide and some handy 11ty i18n hints (just as soon as we work out what all those letters and numbers mean). For a quick rundown in the meantime, check out the TL;DR walkthrough.
Create directories at the site root for each language code (e.g. en
) or language code with country code suffix (e.g. en-GB
):
├─ src
└─ en-GB
├─ about.njk
└─ index.njk
└─ es-ES
├─ about.njk
└─ index.njk
Either is fine. Let's assume we'll need to support multiple dialects in the future, and include country code suffixes.
These directory names determine the lang
value of each language site. This enables Eleventy to infer language when translating terms throughout their pages.
In each language site directory, create a locale data file of the same name. Include dir
and locale
values. E.g. src/en-GB/en-GB.json
{
"dir": "ltr",
"locale": "en-GB"
}
👉 Bonus point: Wherever your main HTML document template is defined, include lang
and dir
attributes:
<html lang="{{ locale }}" dir="{{ dir }}">
Open up your Eleventy config file (probably .eleventy.js
). Import the plugin and use addPlugin
. This is where we provide the translations
and fallbackLocales
as plugin options:
// .eleventy.js
const i18n = require('eleventy-plugin-i18n');
module.exports = function (eleventyConfig) {
eleventyConfig.addPlugin(i18n, {
translations: {
hello: {
'en-GB': 'Hello',
'es-ES': 'Hola'
}
},
fallbackLocales: {
'es-ES': 'en-GB'
}
});
};
translations
Type: Object
| Default: {}
Schema: { [key]: { [locale]: 'String' } }
This object contains our dictionary of translations for each respective language. It can be declared inline within the plugin options (as above), but it might be nicer to lift it out into its own JS module to keep things tidy as it grows:
// .eleventy.js
const i18n = require('eleventy-plugin-i18n');
const translations = require('./src/_data/i18n');
module.exports = function (eleventyConfig) {
eleventyConfig.addPlugin(i18n, {
translations,
fallbackLocales: {
'es-ES': 'en-GB'
}
});
};
// src/_data/i18n/index.js
module.exports = {
hello: {
'en-GB': 'Hello',
'es-ES': 'Hola'
}
};
You might choose to break translations out into their own individual en-GB.js
and es-ES.js
data files, then import and merge them into a single translations
object for the plugin. As long as our translation
schema is the same when you're done, we're good to go! (See API: key
)
Note: These global data files could also be JSON, but we've opted for JS to offer more flexibility around quotation marks and comments.
fallbackLocales
Type: Object
| Default: {}
If a matching translation for a given dictionary item can't be found, the i18n
filter will try to find a fallback from the relevant language based on the fallbackLocales
key/value pairs you specify. In the examples above, we're specifying that should a translation not be available in Spanish, we'll try to fall back to UK English.
You can also use a wildcard *
to specify that all missing translations fall back to a given language:
fallbackLocales: {
'*': 'en-GB'
}
👀 eleventy-plugin-i18n
will warn you in the Node console when the intended translation or fallback values can't be found for a given language based on your translations
data.
Once configured, the i18n
Universal filter is available throughout Nunjucks, Handlebars, Liquid, and JavaScript templates and includes. E.g. To return the translation for our hello
key in Nunjucks or Liquid syntax:
{{ 'hello' | i18n }}
Whether used in a page, layout or include, the filter will automatically determine the correct translation to use based on its site's language. No need to pass locale
everywhere it's used!
i18n(key, data?, localeOverride?)
Returns: String
key
Type: String
The translation lookup key for our dictionary item.
😯 Fun fact: Translation objects can be structured however you like, as long as the locale
is at the end of the chain. i18n
uses lodash's get
under the hood to make dot notation lookups like this easy peasy:
module.exports = {
actions: {
click: {
'en-GB': 'Click',
'es-ES': 'Hacer clic'
}
}
};
{{ 'actions.click' | i18n }}
data
Type: Object
| Default: {}
Translation values can interpolate data using the {{ }}
syntax (thanks to @lukeed's awesome templite
— check out their docs!). For example, given the translation:
module.exports = {
hello_name: {
'en-GB': 'Hello, {{ name }}!',
'es-ES': '¡Hola {{ name }}!'
}
};
{{ 'hello_name' | i18n({ name: 'Eve' }) }}
{# Returns: "Hello, Eve!" or "¡Hola Eve!" #}
localeOverride
Type: String
We can guarantee a translation will always return in a given language by including a localeOverride
as the second argument. For example, this will always render in Spanish, no matter which country site it's in. Muy bueno!
{{ 'hello' | i18n({}, 'es-ES') }}
Note: Here we still have to pass the first data
argument, even if no interpolation is needed. You can pass an empty object {}
or undefined
.
_redirects
to get users to where they need to go).t
or T
filters as an alias for i18n
. Worthwhile for those migrating?pluralize
filter {{ 'apple' | i18n | pluralize(3) }}
(Awesome suggestion from @alexcarpenter).es-ES
url paths are en Español).Read more about Eleventy plugins.
Feedback welcome 🙌
FAQs
Eleventy plugin to assist with dictionary translations
We found that @codegouvfr/eleventy-plugin-i18n demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers 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
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.