Fluent for Lume
A Fluent wrapper to help you easily build multilingual site with Lume.
Requirement
The plugin must be installed AFTER the official plugin, multilanguage
.
Installation
// _config.ts of Lume
import lume from 'lume/mod.ts'
import multilanguage from 'lume/plugins/multilanguage.ts'
import fluent from 'https://deno.land/x/lume_fluent/mod.ts'
const site = lume()
site.use(multilanguage())
site.use(fluent(/* Options */))
export default site
Options
(This section only for stable release; to get the latest options, look for Options
interface in
mod.ts
file)
optionName
type (default value)
- option description
fluentTag
string (“ftl”)- The plugin can use any nonstandard HTML tag name as a placeholder element.
- Default is:
<ftl></ftl>
fallbackLanguage
string (“en”)- The language to get a message if the current language doesn’t have the message. Learn more in Fallback Order
fn
RecordFluentFunction> (undefined)- You can pass your custom function to Fluent file and use it like built-in functions
includes
string (site.options.includes)- Mark Fluent translation file location
- By default, plugin will search for translation in
site.options.includes
extensions
string[] ([“.html”])- For now, please ignore
Usage
Fluent Tag Attributes
If attribute ‘tag’ is set, all the attributes will be kept in the new element except these attributes:
msg
= id (required)tag
= standard-HTML-tag-namevar-*
= FluentVariable
Fallback Order
The order for displaying message is from 1 to 4. Start from number 1:
- Current Language
- Fallback Language
- Message Inside Fluent Tag
- an Empty String
Example:
If you have:
- Fallback language is
en
- 2 Fluent files
vi.ftl
,en.ftl
vi.ftl
may haveawesome-msg
with content “Thông điệp sâu sắc”en.ftl
may haveawesome-msg
with content “A thoughtful message”
- A layout has 1 Fluent tag
<ftl msg='awesome-msg'>Message Inside Fluent Tag</ftl>
.
Here is a several cases:
- Current file is in
vi
&awesome-msg
invi
is available.- Result: “Thông điệp sâu sắc”
- Current file is in
vi
&awesome-msg
invi
is not available buten
does.- Result: “A thoughtful message”
- Current file is in
vi
& no language hasawesome-msg
message key.- Result: “Message Inside Fluent Tag”
- Current file is in
vi
& no language hasawesome-msg
message key. Even worse, the “Message Inside Fluent Tag” is not set, Fluent tag is now an empty tag:- Result: “”
Known Issues
[ P
problem | E
explanation ]
P
The translation tag (<ftl>
) in void element form is not working.E
This was more like upstream problem. In browser DOM parse, only a certain tag name is treated as
void element. The rest (standard & nonstandard) will be automatically wrapped, see
deno-dom#154. Because of that, any attempt to use
Fluent tag as void element <ftl />
will end up loosing all the content below the tag during
replacing process. So for now, even I really want to support void element, there is nothing I can
do.
TODO
- improve error message on notfound (need to point out the content source?)
- fix bug on returning notfound when fallback exists
- improve demo directory
- add testcases
- research on usecase of
extensions
option, it was meant to supportXSLT
but I don’t know how far I can push. - collect data & usage cases on FluentBundle Isolating mode (generate invisible character)