Jitsi Meet Translation ========================== Jitsi Meet uses [i18next](http://i18next.com) library for translation. i18next uses separate json files for each language. Translating Jitsi Meet ====================== The translation of Jitsi Meet is integrated with Pootle. You can translate Jitsi Meet via our Pootle user interface on [http://translate.jitsi.org](http://translate.jitsi.org). **WARNING: Please don't create or edit manually the language files! Please use our Pootle user interface!** Development =========== If you want to add new functionality for Jitsi Meet and you have texts that need to be translated please use our translation module. It is located in modules/translation. You must add key and value in main.json file in English for each translatable text. Than you can use the key to get the translated text for the current language. **WARNING: Please don't change the other language files except main.json! They must be updated and translated via our Pootle user interface!** You can add translatable text in the HTML: * **via attribute on HTML element** - add **data-i18n** attribute with value the key of the translatable text. ``` <span data-i18n="dialog.OK">OK</span> ``` You can also use APP.translation.generateTranslationHTML(key, options) to get this HTML code as Javascript string. ``` APP.translation.generateTranslationHTML("dialog.OK") // returns <span data-i18n="dialog.OK">OK</span> ``` The value in the options parameter will be added in data-i18n-options attribute of the element. **Note:** If you dynamically add HTML elements don't forget to call APP.translation.translateElement(jquery_selector) to translate the text initially. * **via Javascript string** - call APP.translation.translateString(key, options). You can use that method to get the translated string in Javascript and then attach it in the HTML. ``` APP.translation.translateString("dialog.OK") // returns the value for the key of the current language file. "OK" for example. ``` For the available values of ``options`` parameter for the above methods of translation module see [i18next documentation](http://i18next.com/pages/doc_features). **Note:** It is useful to add attributes in the HTML for persistent HTML elements because when the language is changed the text will be automatically translated. Otherwise you should call ``APP.translation.translateString`` and manually change the text every time the language is changed.