4.0.1 • Published 6 months ago

@oliversalzburg/lit-i18n v4.0.1

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

@oliversalzburg/lit-i18n

Forked from https://github.com/colscott/lit-i18n, as that package seems to be no longer maintained.

i18next lit-html directive (could possible add other i18n backends).

Install

yarn add @oliversalzburg/lit-i18n

Usage

Config

Nothing new here. Just use the usual i18next config. You can import from i18next.

i18next.init({
    lng: "en",
    resources: {
        en: {
            translation: {
                whatishow: "{{what}} is {{how}}",
                datamodel:
                    "{{person.name}} is a {{person.age}} year old and is male: {{person.male}}",
            },
        },
        fr: {
            translation: {
                whatishow: "{{what}} est {{how}}",
                datamodel: "{{person.name}} a {{person.age}} ans et est un homme: {{person.male}}",
            },
        },
    },
});

Translations

lit-i18n exposes two directives called translate and translateWhen. The translate directive has the same signature and functionality as the i18next t method. lit-i18n also exposes lit-htmls html and render methods.

translate

import { translate as t, html, render } from "@oliversalzburg/lit-i18n/lib/lit-i18n.js";

/** @typedef {{name: string; age: number; male: boolean}} Person */
class I18nElement extends HTMLElement {
    /** @returns {Person} */
    get person() {
        return this._person;
    }

    /** @param {Person} */
    set person(value) {
        this._person = value;
        render(this.renderTemplate, this);
    }

    /** @inheritdoc */
    constructor() {
        super();
    }

    /** @inheritdoc */
    connectedCallback() {
        if (!this.person) {
            this.person = {
                name: "None",
                age: 0,
                male: false,
            };
        }
    }

    /** @returns {import('lit-html/lit-html').TemplateResult} */
    get renderTemplate() {
        return html`
            <div title="${t("whatishow", { what: "i18next", how: "great" })}"></div>
            <span>${t("datamodel", { person: this.person })}</span>
        `;
    }
}

translateWhen directive - postponing translations until they have loaded

Screen flicker can occur if you load multiple namespaces and run translations prior to the translation resource being loaded. I18next returns promises that will resolve after the resources are ready. If this happens you can use translateWhen. translateWhen differs to translate in that it also accepts a Promise. This Promise would typically be the Promise returned by i18next.init or i18next.loadNamespaces or i18next.loadLanguages. The translateWhen directive will not try to translate the key until the Promise is resolved. Passing the Promise every single time you call the directive can get a little much so you can wrap the directive and call the wrapper instead, like this:

import { translateWhen } from '@oliversalzburg/lit-i18n/lib/lit-i18n.js';

const initializePromise = i18next.use(someBackend).init(....);
const translateDirective = (keys, options) => translateWhen(initializePromise, keys, options);

// Now you can use translateDirective in your lit-html templates.
html`<div>${translateDirective('some.key')}</div>`