Migrating i18n
Adding Base Internationalization Support
The I18nDecorator
is usually applied at the root level of an application and provides basic internationalization support to your application. It adds locale and text directionality CSS classes, provides automatic re-rendering when the locale changes via the onlanguagechange
event, and adds context
parameters for downstream components to update the locale or determine the current text directionality.
Note:
MoonstoneDecorator
automatically appliesI18nDecorator
by default but can be disabled by settings itsi18n
config property tofalse
.
ilib Modules
ilib
modules are supplied with the i18n
library but can be imported using an enact cli
provided shortcut:
Previous: enyo-ilib/[MODULE_NAME]
Current: ilib/[MODULE_NAME]
String translation
Previous: $L()
Current: $L()
import $L from '@enact/i18n/$L';
const MyTranslatedString = $L('Hello World');
String Translation - ilib string
Previous: $L.rb()
Current: toIString()
import {toIString} from '@enact/i18n/$L';
const MyIString = toIString('Hello IString');
const MyIStringText = MyIString.toString();
Updating the locale
Previous: The updateLocale()
method of the enyo/i18n
library could be invoked
Current: The updateLocale()
method is available for any component whose ancestor is wrapped with the I18nDecorator
, which provides this method as part of the Context API. I18nDecorator
provides easy access via the I18nContextDecorator
HOC which can provide the locale, rtl state, and updateLocale
method via props by specifying the localeProp
, rtlProp
, and updateLocaleProp
configuration options, respectively.
import Button from '@enact/moonstone/Button';
import {I18nContextDecorator} from '@enact/i18n/I18nDecorator';
import React from 'react';
const MyComponent = I18nContextDecorator(
{updateLocaleProp: 'updateLocale'},
class extends React.Component {
setLocale = (locale) => () => {
const {updateLocale} = this.props;
updateLocale(locale);
}
render () {
return (
<div>
<Button onClick={this.setLocale('ar-SA')} size="small">ar-SA</Button>
<Button onClick={this.setLocale('en-US')} size="small">en-US</Button>
<Button onClick={this.setLocale('ko-KR')} size="small">ko-KR</Button>
<Button onClick={this.setLocale('th-TH')} size="small">th-TH</Button>
</div>
);
}
}
);
Current Locale Text Directionality
Previous: Components could check the value of this.rtl
Current: The rtl
state method is available for any component whose ancestor is wrapped with the I18nDecorator
, which provides this value as part of the Context API. I18nDecorator
provides easy access via the I18nContextDecorator
HOC which can provide the locale, rtl state, and updateLocale
method via props by specifying the localeProp
, rtlProp
, and updateLocaleProp
configuration options, respectively.
import Button from '@enact/moonstone/Button';
import {I18nContextDecorator} from '@enact/i18n/I18nDecorator';
import React from 'react';
const MyComponent = I18nContextDecorator(
{rtlProp: 'rtl'},
class extends React.Component {
render () {
const {rtl} = this.props;
return (
<Button>My {rtl ? 'RTL' : 'LTR'} button</Button>
);
}
}
);
Determine Text Directionality
Previous: isRtl()
provided by enyo/utils
Current: isRtlText()
provided by @enact/i18n/util
import {isRtlText} from '@enact/i18n/util';
const isHebrewRtl = isRtlText('שועל החום');
const isEnglishRtl = isRtlText('LTR Text');
i18n Classes
Previous: enyo-locale-...
Current: enact-locale-...
.div .enact-locale-non-latin {
background-color: green;
}