Skip to content

Latest commit

 

History

History
70 lines (54 loc) · 1.89 KB

translations.md

File metadata and controls

70 lines (54 loc) · 1.89 KB

🦉 Translations 🦉

If properly setup, Owl can translate all rendered templates. To do so, it needs a translate function, which takes a string and returns a string.

For example:

const translations = {
  hello: "bonjour",
  yes: "oui",
  no: "non",
};
const translateFn = (str) => translations[str] || str;

const app = new App(Root, { templates, tranaslateFn });
// ...

See the app configuration page for more info on how to configure an Owl application.

Once setup, all rendered templates will be translated using translateFn:

  • each text node will be replaced with its translation,
  • each of the following attribute values will be translated as well: title, placeholder, label and alt,
  • translating text nodes can be disabled with the special attribute t-translation, if its value is off.

So, with the above translateFn, the following templates:

<div>hello</div>
<div t-translation="off">hello</div>
<div>Are you sure?</div>
<input placeholder="hello" other="yes"/>

will be rendered as:

<div>bonjour</div>
<div>hello</div>
<div>Are you sure?</div>
<input placeholder="bonjour" other="yes"/>

Note that the translation is done during the compilation of the template, not when it is rendered.

In some case, it is useful to be able to extend the list of translatable attributes. For example, one may want to also translate data-title attributes. To do that, we can define additional attributes with the translatableAttributes option:

const app = new App(Root, { templates, tranaslateFn, translatableAttributes: ["data-title"] });
// ...

It is also possible to remove an attribute from the default list by prefixing it with -:

const app = new App(Root, {
  templates,
  tranaslateFn,
  translatableAttributes: ["data-title", "-title"],
});
// data-title attribute will be translated, but not title attribute...