JavaScript translation

Zikula includes willdurand/js-translation-bundle also known as BazingaJsTranslationBundle.

Bazinga adds native symfony translation support like so:

var myText = Translator.trans('Foo bar baz');
var myChoiceText = Translator.transChoice('%count% foo|%count% foos', 5);

The methods are defined like so:

Translator.trans(key, params, domain, locale);
Translator.transChoice(key, count, params, domain, locale);

See BazingaJsTranslation docs for further details and examples.

Extraction from JavaScript files

Zikula also provides an Extractor for both native Symfony and Zikula translation functions. This is run automatically when translations are extracted. By default, all javascript translations are added to the messages domain (same as in PHP, too). This catalog is automatically added to every page.

If an extension chooses, it can set the domain manually in each method call, e.g.:

var myText = Translator.trans('Foo bar baz', {}, 'special_domain');

In this case, the extractor will export these strings to its own translation file:


Then, your extension must manually include each of these files in the required template like so:

{{ pageAddAsset('javascript', url('bazinga_jstranslation_js', {domain: 'special_domain'}), constant('Zikula\\ThemeModule\\Engine\\AssetBag::WEIGHT_JS_TRANSLATIONS')) }}

JavaScripts in Twig templates

Translation usage in scripts that are created within a twig template (not a standalone file) should utilize standard Twig template translation and not utilize javascript translation.