2017-09-26 18:52:32 +02:00
|
|
|
# Introduction <a id="module-translation-introduction"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2021-05-28 13:55:03 +02:00
|
|
|
Icinga Web 2 provides localization out of the box - for itself and the core modules.
|
|
|
|
This module is for third party module developers to aid them to localize their work.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-10-09 15:52:10 +02:00
|
|
|
The chapters [Translation for Developers](03-Translation.md#module-translation-developers),
|
|
|
|
[Translation for Translators](03-Translation.md#module-translation-translators) and
|
2021-05-28 13:55:03 +02:00
|
|
|
[Testing Translations](03-Translation.md#module-translation-tests) will introduce and
|
|
|
|
explain you, how to take part on localizing modules to different languages.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
## Translation for Developers <a id="module-translation-developers"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2020-05-12 11:45:27 +02:00
|
|
|
To make use of the built-in translations in your module's code or views, you should use the method
|
2014-09-11 12:55:02 +02:00
|
|
|
`$this->translate('String to be translated')`, let's have a look at an example:
|
|
|
|
|
|
|
|
```php
|
|
|
|
<?php
|
|
|
|
|
|
|
|
class ExampleController extends Controller
|
|
|
|
{
|
|
|
|
public function indexAction()
|
|
|
|
{
|
|
|
|
$this->view->title = $this->translate('Hello World');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
So if there a translation available for the `Hello World` string you will get an translated output, depends on the
|
2017-09-26 18:52:32 +02:00
|
|
|
language which is set in your configuration as the default language, if it is `de_DE` the output would be
|
2014-09-11 12:55:02 +02:00
|
|
|
`Hallo Welt`.
|
|
|
|
|
|
|
|
The same works also for views:
|
|
|
|
|
|
|
|
```
|
|
|
|
<h1><?= $this->title ?></h1>
|
|
|
|
<p>
|
|
|
|
<?= $this->translate('Hello World') ?>
|
|
|
|
<?= $this->translate('String to be translated') ?>
|
|
|
|
</p>
|
|
|
|
```
|
|
|
|
|
|
|
|
If you need to provide placeholders in your messages, you should wrap the `$this->translate()` with `sprintf()` for e.g.
|
|
|
|
sprintf($this->translate('Hello User: (%s)'), $user->getName())
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
### Translating plural forms <a id="module-translation-plural-forms"></a>
|
2014-09-16 16:26:09 +02:00
|
|
|
|
|
|
|
To provide a plural translation, just use the `translatePlural()` function.
|
|
|
|
|
|
|
|
```php
|
|
|
|
<?php
|
|
|
|
|
|
|
|
class ExampleController extends Controller
|
|
|
|
{
|
|
|
|
public function indexAction()
|
|
|
|
{
|
|
|
|
$this->view->message = $this->translatePlural('Service', 'Services', 3);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
### Context based translation <a id="module-translation-context-based"></a>
|
2014-09-16 16:26:09 +02:00
|
|
|
|
|
|
|
If you want to provide context based translations, you can easily do it with an extra parameter in both methods
|
|
|
|
`translate()` and `translatePlural()`.
|
|
|
|
|
|
|
|
```php
|
|
|
|
<?php
|
|
|
|
|
|
|
|
class ExampleController extends Controller
|
|
|
|
{
|
|
|
|
public function indexAction()
|
|
|
|
{
|
2020-05-12 11:45:27 +02:00
|
|
|
$this->view->title = $this->translate('My Title', 'mycontext');
|
2014-09-16 16:26:09 +02:00
|
|
|
$this->view->message = $this->translatePlural('Service', 'Services', 3, 'mycontext');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
## Translation for Translators <a id="module-translation-translators"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2020-05-12 11:45:27 +02:00
|
|
|
> **Note**:
|
|
|
|
>
|
|
|
|
> If you want to translate Icinga Web 2 or any module made by Icinga, please head over to
|
|
|
|
> [Icinga/L10n](https://github.com/Icinga/L10n) instead. We won't accept any contributions
|
|
|
|
> in this regard other than those made there.
|
|
|
|
|
2014-09-11 12:55:02 +02:00
|
|
|
Icinga Web 2 internally uses the UNIX standard gettext tool to perform internationalization, this means translation
|
|
|
|
files in the .po file format are supplied for text strings used in the code.
|
|
|
|
|
|
|
|
There are a lot of tools and techniques to work with .po localization files, you can choose what ever you prefer. We
|
|
|
|
won't let you alone on your first steps and therefore we'll introduce you a nice tool, called Poedit.
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
### Poedit <a id="module-translation-translators-poedit"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
First of all, you have to download and install [Poedit](http://poedit.net).
|
|
|
|
When you are done, you have to configure Poedit.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
#### Configuration <a id="module-translation-translators-poedit-configuration"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
`Personalize`: Please provide your Name and E-Mail under Identity.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2016-09-01 11:29:14 +02:00
|
|
|
![Personalize](img/poedit_001.png)
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
`Editor`: Under the `Behavior` the Automatically compile .mo files on save, should be disabled.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2016-09-01 11:29:14 +02:00
|
|
|
![Editor](img/poedit_002.png)
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
`Translations Memory`: Under the `Database` please add your languages, for which are you writing translations.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2016-09-01 11:29:14 +02:00
|
|
|
![Translations Memory](img/poedit_003.png)
|
2014-09-11 12:55:02 +02:00
|
|
|
|
|
|
|
When you are done, just save your new settings.
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
#### Editing .po files <a id="module-translation-translators-poedit-edit-po-files"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2020-05-12 11:45:27 +02:00
|
|
|
> **Note**
|
|
|
|
>
|
|
|
|
> ll_CC stands for ll=language and CC=country code for e.g `de_DE`, `fr_FR`, `ru_RU`, `it_IT` etc.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2020-05-12 11:45:27 +02:00
|
|
|
To work with .po files, open or create the one for your language located under
|
|
|
|
`application/locale/ll_CC/LC_MESSAGES/yourmodule.po`. As shown below, you will
|
|
|
|
get then a full list of all available translation strings for the module. Each
|
|
|
|
module names its translation files `%module_name%.po`.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2016-09-01 11:29:14 +02:00
|
|
|
![Full list of strings](img/poedit_004.png)
|
2014-09-11 12:55:02 +02:00
|
|
|
|
|
|
|
Now you can make changes and when there is no translation available, Poedit would mark it with a blue color, as shown
|
|
|
|
below.
|
|
|
|
|
2016-09-01 11:29:14 +02:00
|
|
|
![Untranslated strings](img/poedit_005.png)
|
2014-09-11 12:55:02 +02:00
|
|
|
|
|
|
|
And when you want to test your changes, please read more about under the chapter
|
|
|
|
[Testing Translations](Testing Translations).
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
## Testing Translations <a id="module-translation-tests"></a>
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2020-09-14 18:35:23 +02:00
|
|
|
If you want to try out your translation changes in Icinga Web 2, you can make use of the CLI translations commands.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
> **Note**:
|
|
|
|
>
|
|
|
|
> Please make sure that the gettext package is installed
|
2014-09-11 12:55:02 +02:00
|
|
|
|
|
|
|
To get an easier development with translations, you can activate the `translation module` which provides CLI commands,
|
|
|
|
after that you would be able to refresh and compile your .po files.
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
Let's assume, we want to provide German translations for our just new created module `yourmodule`.
|
2014-09-11 12:55:02 +02:00
|
|
|
|
|
|
|
If we haven't yet any translations strings in our .po file or even the .po file, we can use the CLI command, to do the
|
|
|
|
job for us:
|
|
|
|
|
2017-09-26 18:52:32 +02:00
|
|
|
```
|
2020-05-12 11:45:27 +02:00
|
|
|
icingacli translation refresh module yourmodule de_DE
|
2017-09-26 18:52:32 +02:00
|
|
|
```
|
2014-09-11 12:55:02 +02:00
|
|
|
|
|
|
|
This will go through all .php and .phtml files inside the module and a look after `$this->translate()` if there is
|
2017-09-26 18:52:32 +02:00
|
|
|
something to translate - if there is something and is not available in the `yourmodule.po` it will update this file
|
|
|
|
for us with new strings.
|
|
|
|
|
2020-05-12 11:45:27 +02:00
|
|
|
Now you can open the `application/locale/de_DE/LC_MESSAGES/yourmodule.po` and you will see something similar:
|
2017-09-26 18:52:32 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
# Icinga Web 2 - Head for multiple monitoring backends.
|
|
|
|
# Copyright (C) 2014 Icinga Development Team
|
|
|
|
# This file is distributed under the same license as Development Module.
|
|
|
|
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
|
|
|
|
#
|
|
|
|
msgid ""
|
|
|
|
msgstr ""
|
|
|
|
"Project-Id-Version: Development Module (0.0.1)\n"
|
|
|
|
"Report-Msgid-Bugs-To: dev@icinga.com\n"
|
|
|
|
"POT-Creation-Date: 2014-09-09 10:12+0200\n"
|
|
|
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
|
|
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
|
|
|
"Language: ll_CC\n"
|
|
|
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
|
|
|
"MIME-Version: 1.0\n"
|
|
|
|
"Content-Type: text/plain; charset=UTF-8\n"
|
|
|
|
"Content-Transfer-Encoding: 8bit\n"
|
|
|
|
|
|
|
|
#: /modules/yourmodule/configuration.php:6
|
|
|
|
msgid "yourmodule"
|
|
|
|
msgstr ""
|
|
|
|
```
|
|
|
|
|
|
|
|
Great, now you can adjust the file and provide the German `msgstr` for `yourmodule`.
|
|
|
|
|
|
|
|
```
|
|
|
|
#: /modules/yourmodule/configuration.php:6
|
|
|
|
msgid "Dummy"
|
|
|
|
msgstr "Attrappe"
|
|
|
|
```
|
|
|
|
|
|
|
|
The last step is to compile the `yourmodule.po` to the `yourmodule.mo`:
|
|
|
|
|
|
|
|
```
|
2020-05-12 11:45:27 +02:00
|
|
|
icingacli translation compile module yourmodule de_DE
|
2017-09-26 18:52:32 +02:00
|
|
|
```
|
2014-09-11 12:55:02 +02:00
|
|
|
|
2020-05-12 11:45:27 +02:00
|
|
|
> **Note**
|
|
|
|
>
|
|
|
|
> After compiling it you need to restart the web server to get new translations available in your module.
|
|
|
|
|
|
|
|
At this moment, everywhere in the module where the `Dummy` should be translated, it would return the translated
|
2015-03-08 14:39:53 +01:00
|
|
|
string `Attrappe`.
|