4 releases (2 stable)
1.0.1 | Jul 22, 2024 |
---|---|
0.1.1 | Jul 20, 2024 |
0.1.0 | Jul 10, 2024 |
#43 in Internationalization (i18n)
41KB
725 lines
Yew translator
A i18n implementation for yew using a string templater.
Based on Yew I18n, this implementation has slight differences and is making use of string templaters.
Features
By default, all features are enabled.
yew-i18n
Using the feature yew-i18n
allows you to use the i18n
component made for yew
.
handlebars
Using the feature yew-i18n
with handlebars
allows you to use the yew-i18n
with the handlebars
implementation.
translation_templater
Using the feature yew-i18n
with translation_templater
allows you to use the yew-i18n
with the custom templater implementation.
export_translation_templater
Using export_translation_templater
allows you to use the custom templater independently from the implementation of i18n
.
i18n
Translation Templater
Translation Templater is the custom templater written specifically for this implementation of yew-i18n
.
If you're not using the feature handlebars
, this will be the one used by default.
How to use
When importing yew_translator
in your project, consider only using the yew-i18n
like this:
[dependencies]
yew_translator = { version = "1.0", default-features = false, features = ["yew-i18n", "translation_templater"] }
This allows to remove access that you won't need, except if you want to create your own i18n
for something else than yew
(for this case, you can remove the yew-i18n
feature if you want and you'll get rid of yew
from this crate, and you'll be free to use only the parser with the feature export_translation_templater
).
Now, create your yew component and initialize your i18n
inside it:
use yew_translator::*;
...
let supported_languages = vec!["en", "fr"];
let mut translations: HashMap<String, serde_json::Value> = HashMap::new(); // Import your own translations (language -> transation JSON)
html!(
<I18nProvider {supported_languages} {translations}>
<WhateverYouWant />
</I18nProvider>
)
Finaly, in a child component, use the hook use_translation()
to handle translations like in Yew I18n (some field names may vary).
By default, en
and fr
are in the field supported_languages
, but you can change this by inserting your own language codes.
For the field translations
, you must have a hashmap containing the language associated with the JSON
containing your translations.
Finaly, you can use the field current_language
to set your own default language used by i18n
. By default, current_language
is set to en
.
JSON translations
You can write your JSON using the system of key
: value
using the dot notation to mark the child access (even on array).
So for a JSON such as:
{
"root": {
"child_a": ["elem_0", "elem_1", "elem_2", {
"name": "Janne"
}],
"child_b": {
"first_name": "John",
"last_name": "Doe",
"age": 25
}
}
}
You'll get all the following paths:
root.child_a.0
root.child_a.1
root.child_a.2
root.child_a.3.name
root.child_b.first_name
root.child_b.last_name
root.child_b.age
Templates and Data
Following the t
method used by yew-i18n
, you'll find the method tt
where you'll put the key of the value you want and you'll insert data to inject in the template found from the key.
Now, you'll treat all your values as templates where you'll be able to do some injections.
The syntax is the following:
{{data_field_name}}
: inject a value from your data in the template. (No parsing){{*data_field_name}}
: use the value of your data as a key of your translations to inject it's value. (No parsing){{{translation_field_name}}}
: use the value of your translation key to inject it's template, forcing you to also inject the needed values. (Parsing happen){{{*data_field_name}}}
: use the value of your data as a key of your translations to inject it's template, forcing you to also inject the needed values. (Parsing happen){{{**data_field_name}}}
: use the value of your data as a template for your translations, helping with the creation of dynamic templates using references. (Parsing happen)
Here's some rules to also follow:
- The
\
symbol followed by{
,}
or\
will always escape the next character, making\
ignored in the output. - When parsing the key name, the symbol
\
followed by*
will result in the character*
being outputed. - Escaping the
*
symbol is only useful right after a{{
or{{{
. - You can have as many template as you want inside other template, but be careful of infinite loops.
Handlebars
If you've not heard of it already, checkout handlebars crates to know more about it.
How to use
When importing yew_translator
in your project, consider only using the yew-i18n
like this:
[dependencies]
yew_translator = { version = "1.0", default-features = false, features = ["yew-i18n", "handlebars"] }
When using handlebars, use the thb
and thb_register
methods (for thb_register
, you'll be able to inject your own Handlebars
registry, the one from tbh
is an empty one).
Dependencies
~3–11MB
~137K SLoC