.. _Translation setup: ================= Translation setup ================= Nextcloud's translation system is powered by `Transifex `_. To start translating sign up and enter a group. If your community app should be translated by the `Nextcloud community on Transifex `_ just follow the setup section below. Translation tool ---------------- .. note:: The tool-based translation currently only supports repositories hosted on ``github.com``. If your app is hosted elsewhere, you can try to follow the :ref:`manual-translation` instead. The `translation tool `_ scrapes the source code for method calls to ``t()`` or ``n()`` to extract the strings that should be translated. If you check in minified JS code for example then those method names are also quite common and could cause wrong extractions. For this reason we allow to specify a list of files that the translation tool will not scrape for strings. You simply need to add a file named :file:`.l10nignore` into the root folder of your app and specify the files one per line:: # compiled vue templates js/bruteforcesettings.js Setup of the transifex sync --------------------------- Transifex configuration ``.tx/config`` ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ To setup the transifex sync within the Nextcloud community you need to add first the transifex config to your app folder at :file:`.tx/config` (please replace ``MYAPP`` with your apps id): .. code-block:: ini [main] host = https://www.transifex.com lang_map = hu_HU: hu, nb_NO: nb, sk_SK: sk, th_TH: th, ja_JP: ja, bg_BG: bg, cs_CZ: cs, fi_FI: fi [o:nextcloud:p:nextcloud:r:{{APPID}}] file_filter = translationfiles//{{APPID}}.po source_file = translationfiles/templates/{{APPID}}.pot source_lang = en type = PO Then create a folder :file:`l10n` and a file :file:`l10n/.gitkeep` to create an empty folder which later holds the translations. Branch selection ``.tx/backport`` ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The bot will run every night and only push commits to the following branches branch once there is an update to the translation: * main * master * stableX (X being the recent 3 versions of Nextcloud Server) You can overwrite this list by creating a file ``.tx/backport`` in your repository with the following content:: develop stable That would sync the translations for the branches (``main`` and ``master`` are added automatically): * main * master * develop * stable Excluding files ``.l10nignore`` ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Add one more file called :file:`.l10nignore` in root of the repository and the files and folders to ignore for translations. This should be used to exclude files that create false-positive translations, such as: - Compiled JavaScript files ``js/`` - 3rd-party PHP dependencies ``vendor/`` - Non-shipped files and documentation ``docs/`` Validate source strings ^^^^^^^^^^^^^^^^^^^^^^^ After finishing the setup, you can validate the translation source strings which outlines some common mistakes. Clone the `nextcloud/docker-ci `_ repository and afterwards run the following script: .. code:: sh bash translations/validateSyncSetup.sh Owner Repository Repository permissions ^^^^^^^^^^^^^^^^^^^^^^ Now the GitHub account `@nextcloud-bot `_ needs to get ``write`` access to your repository. You can invite it from your repository settings:: https://github.com///settings/access After sending the invitation, please `open a ticket using the "Request translations" template `_. .. attention:: In general you should enable the `protected branches feature `_ for default and stable branches. If you do that, you need to grant the `@nextcloud-bot `_ ``admin`` permissions and allow administrators to bypass the protection. This feature however is only possible for repositories owned by organizations, not in repositories owned by individuals! You can `create your own organization `_ If you need help just `open a ticket with the request `_ and we can also guide you through the steps. .. _manual-translation: Manual translation ------------------ If Transifex is not the right choice or the app is not accepted for translation, generate the gettext strings by yourself by executing our `translation tool `_ in the app folder:: cd /srv/http/nextcloud/apps/myapp translationtool.phar create-pot-files The translation tool requires ``gettext``, installable via:: apt-get install gettext The above tool generates a template that can be used to translate all strings of an app. This template is located in the folder :file:`translationfiles/template/` with the name :file:`myapp.pot`. It can be used by your favored translation tool such as `Poedit `_. It then creates a :file:`.po` file. The :file:`.po` file needs to be placed in a folder named like the language code with the app name as filename - for example :file:`translationfiles/es/myapp.po`. After this step the tool needs to be invoked to transfer the po file into our own fileformat that is more easily readable by the server code:: translationtool.phar convert-po-files Now the following folder structure is available:: myapp/l10n |-- es.js |-- es.json myapp/translationfiles |-- es | |-- myapp.po |-- templates |-- myapp.pot You then just need the :file:`.json` and :file:`.js` files for a working localized app.