- Structural directive is now a memoized function:
// before {{ t.a.b }} {{ t.hello }} {{ t.someKey | translocoParams: { value: 'value' } }}
After:
{{ t('a.b') }} {{ t('hello') }} {{ t('someKey', { value: 'value' }) }}
- Dedicated method for when you need to query an object instead of a key:
// Before
service.translate('a.b', params);
service.selectTranslate('a.b', params);
// After
service.translateObject('a.b', params);
service.selectTranslateObject('a.b', params);
MissingHandler
interface: removes the second redundantparams
param. (only relevant if you implemented a custom handler)
We also made minor changes in TranslocoConfig
:
- It's now required to set the available languages in your application:
- We have changed the
listenToLangChange
flag to a more clearreRenderOnLangChange
:
{
provide: TRANSLOCO_CONFIG,
useValue: {
availableLangs: ['en', 'es'],
reRenderOnLangChange: true
}
}
We also allow passing an object
making it easier for you to use it in a languages dropdown:
[{ id: 'en', label: 'English'}]
We need this information to know whether we're dealing with a language
or a scope
.
- Change
config.listenToLangChange
toconfig.reRenderOnLangChange
to make it more clear. - Remove callback param support from
translate()
. - Remove messageformat from the library in favor of the external library.
We created a schematics command that'll do most of the work for you
ng g @ngneat/transloco:upgrade
See v2-upgrade.md for more information.
- Each translation file is now flatten in runtime. This change brings benefits such as lower memory consumption, and faster value accessor.
- Missing handler support for the structural directive.
- Transloco optimizes library which will minify the translation files, flatten AOT, and removes comments.
- Support a fallback language for missing translation value or key.
- Set a scope alias directly in
TRANSLOCO_SCOPE
.
A Transloco CLI tool that builds the translation files based on your code in development. Inform you about missing keys and extras. Stay tuned.