Fluent Templates: A High level Fluent API.
fluent-templates
lets you to easily integrate Fluent localisation into
your Rust application or library. It does this by providing a high level
"loader" API that loads fluent strings based on simple language negotiation,
and the FluentLoader
struct which is a Loader
agnostic container type
that comes with optional trait implementations for popular templating
engines such as handlebars or tera that allow you to be able to use your
localisations in your templates with no boilerplate.
Loaders
Currently this crate provides two different kinds of loaders that cover two main use cases.
-
static_loader!
— A procedural macro that loads your fluent resources at compile-time into your binary and creates a newStaticLoader
static variable that allows you to access the localisations.static_loader!
is most useful when you want to localise your application and want to ship your fluent resources with your binary. -
ArcLoader
— A struct that loads your fluent resources at run-time usingArc
as its backing storage.ArcLoader
is most useful for when you want to be able to change and/or update localisations at run-time, or if you're writing a developer tool that wants to provide fluent localisation in your own application such as a static site generator.
static_loader!
The easiest way to use fluent-templates
is to use the static_loader!
procedural macro that will create a new StaticLoader
static variable.
Basic Example
!
static_loader
Customise Example
You can also modify each FluentBundle
on initialisation to be able to
change configuration or add resources from Rust.
use FluentResource;
use static_loader;
use Lazy;
static_loader!
Locales Directory
fluent-templates
will collect all subdirectories that match a valid
Unicode Language Identifier and bundle all fluent files found in
those directories and map those resources to the respective identifier.
fluent-templates
will recurse through each language directory as needed
and will respect any .gitignore
or .ignore
files present.
Example Layout
locales
├── core.ftl
├── en-US
│ └── main.ftl
├── fr
│ └── main.ftl
├── zh-CN
│ └── main.ftl
└── zh-TW
└── main.ftl
Looking up fluent resources
You can use the Loader
trait to lookup
a given fluent resource, and
provide any additional arguments as needed with lookup_with_args
.
Example
# In `locales/en-US/main.ftl`
hello-world = Hello World!
greeting = Hello { $name }!
# In `locales/fr/main.ftl`
hello-world = Bonjour le monde!
greeting = Bonjour { $name }!
# In `locales/de/main.ftl`
hello-world = Hallo Welt!
greeting = Hallo { $name }!
use HashMap;
use ;
use ;
const US_ENGLISH: LanguageIdentifier = langid!;
const FRENCH: LanguageIdentifier = langid!;
const GERMAN: LanguageIdentifier = langid!;
static_loader!
Tera
With the tera
feature you can use FluentLoader
as a Tera function.
It accepts a key
parameter pointing to a fluent resource and lang
for
what language to get that key for. Optionally you can pass extra arguments
to the function as arguments to the resource. fluent-templates
will
automatically convert argument keys from Tera's snake_case
to the fluent's
preferred kebab-case
arguments.
= { = "*", = ["tera"] }
use ;
static_loader!
Handlebars
In handlebars, fluent-templates
will read the lang
field in your
handlebars::Context
while rendering.
= { = "*", = ["handlebars"] }
use ;
static_loader!
Handlebars helper syntax.
The main helper provided is the {{fluent}}
helper. If you have the
following Fluent file:
foo-bar = "foo bar"
placeholder = this has a placeholder { $variable }
placeholder2 = this has { $variable1 } { $variable2 }
You can include the strings in your template with
<!-- will render "foo bar" -->
{{fluent "foo-bar"}}
<!-- will render "this has a placeholder baz" -->
{{fluent "placeholder" variable="baz"}}
You may also use the {{fluentparam}}
helper to specify variables,
especially if you need them to be multiline.
{{#fluent "placeholder2"}}
{{#fluentparam "variable1"}}
first line
second line
{{/fluentparam}}
{{#fluentparam "variable2"}}
first line
second line
{{/fluentparam}}
{{/fluent}}
FAQ
Why is there extra characters around the values of arguments?
These are called "Unicode Isolating Marks" that used to allow the text to be bidirectional.
You can disable this with FluentBundle::set_isolating_marks
being set to false
.
static_loader!