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:
MoonstoneDecoratorautomatically appliesI18nDecoratorby default but can be disabled by settings itsi18nconfig 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;
}