2014-01-29 16:25:08 +01:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2014 Icinga Development Team | GPLv2+ */
|
2014-01-29 16:25:08 +01:00
|
|
|
|
|
|
|
namespace Icinga\Util;
|
|
|
|
|
2021-05-20 12:42:12 +02:00
|
|
|
use ipl\I18n\GettextTranslator;
|
|
|
|
use ipl\I18n\Locale;
|
|
|
|
use ipl\I18n\StaticTranslator;
|
2014-01-29 16:25:08 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper class to ease internationalization when using gettext
|
2021-05-20 12:42:12 +02:00
|
|
|
*
|
|
|
|
* @deprecated Use {@see \ipl\I18n\StaticTranslator::$instance} or {@see \ipl\I18n\Translation} instead
|
2014-01-29 16:25:08 +01:00
|
|
|
*/
|
|
|
|
class Translator
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The default gettext domain used as fallback
|
|
|
|
*/
|
|
|
|
const DEFAULT_DOMAIN = 'icinga';
|
|
|
|
|
|
|
|
/**
|
2014-01-30 13:17:15 +01:00
|
|
|
* The locale code that is used in the project
|
|
|
|
*/
|
2014-02-03 12:22:13 +01:00
|
|
|
const DEFAULT_LOCALE = 'en_US';
|
2014-01-30 13:17:15 +01:00
|
|
|
|
2014-01-29 16:25:08 +01:00
|
|
|
/**
|
|
|
|
* Translate a string
|
|
|
|
*
|
|
|
|
* Falls back to the default domain in case the string cannot be translated using the given domain
|
|
|
|
*
|
2014-12-19 11:29:24 +01:00
|
|
|
* @param string $text The string to translate
|
|
|
|
* @param string $domain The primary domain to use
|
2014-09-16 15:19:23 +02:00
|
|
|
* @param string|null $context Optional parameter for context based translation
|
2014-01-29 16:25:08 +01:00
|
|
|
*
|
2014-09-16 15:19:23 +02:00
|
|
|
* @return string The translated string
|
2014-01-29 16:25:08 +01:00
|
|
|
*/
|
2014-09-16 15:19:23 +02:00
|
|
|
public static function translate($text, $domain, $context = null)
|
2014-01-29 16:25:08 +01:00
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
return StaticTranslator::$instance->translateInDomain($domain, $text, $context);
|
2014-01-29 16:25:08 +01:00
|
|
|
}
|
|
|
|
|
2014-09-15 14:11:42 +02:00
|
|
|
/**
|
|
|
|
* Translate a plural string
|
|
|
|
*
|
2014-09-29 15:56:48 +02:00
|
|
|
* Falls back to the default domain in case the string cannot be translated using the given domain
|
|
|
|
*
|
2014-09-15 14:11:42 +02:00
|
|
|
* @param string $textSingular The string in singular form to translate
|
|
|
|
* @param string $textPlural The string in plural form to translate
|
2014-12-19 11:29:24 +01:00
|
|
|
* @param integer $number The amount to determine from whether to return singular or plural
|
2014-09-15 14:11:42 +02:00
|
|
|
* @param string $domain The primary domain to use
|
2014-09-16 15:19:23 +02:00
|
|
|
* @param string|null $context Optional parameter for context based translation
|
2014-09-15 14:11:42 +02:00
|
|
|
*
|
|
|
|
* @return string The translated string
|
|
|
|
*/
|
2014-09-16 15:19:23 +02:00
|
|
|
public static function translatePlural($textSingular, $textPlural, $number, $domain, $context = null)
|
2014-09-11 18:04:10 +02:00
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
return StaticTranslator::$instance->translatePluralInDomain(
|
|
|
|
$domain,
|
|
|
|
$textSingular,
|
|
|
|
$textPlural,
|
|
|
|
$number,
|
|
|
|
$context
|
|
|
|
);
|
2014-09-11 18:04:10 +02:00
|
|
|
}
|
|
|
|
|
2014-09-16 15:19:23 +02:00
|
|
|
/**
|
|
|
|
* Emulated pgettext()
|
|
|
|
*
|
|
|
|
* @link http://php.net/manual/de/book.gettext.php#89975
|
|
|
|
*
|
|
|
|
* @param $text
|
|
|
|
* @param $domain
|
|
|
|
* @param $context
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function pgettext($text, $domain, $context)
|
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
return StaticTranslator::$instance->translateInDomain($domain, $text, $context);
|
2014-09-16 15:19:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emulated pngettext()
|
|
|
|
*
|
|
|
|
* @link http://php.net/manual/de/book.gettext.php#89975
|
|
|
|
*
|
|
|
|
* @param $textSingular
|
|
|
|
* @param $textPlural
|
|
|
|
* @param $number
|
|
|
|
* @param $domain
|
|
|
|
* @param $context
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function pngettext($textSingular, $textPlural, $number, $domain, $context)
|
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
return StaticTranslator::$instance->translatePluralInDomain(
|
2015-03-30 22:42:29 +02:00
|
|
|
$domain,
|
2021-05-20 12:42:12 +02:00
|
|
|
$textSingular,
|
2015-03-30 22:42:29 +02:00
|
|
|
$textPlural,
|
|
|
|
$number,
|
2021-05-20 12:42:12 +02:00
|
|
|
$context
|
2015-03-30 22:42:29 +02:00
|
|
|
);
|
2014-09-16 15:19:23 +02:00
|
|
|
}
|
|
|
|
|
2014-01-29 16:25:08 +01:00
|
|
|
/**
|
|
|
|
* Register a new gettext domain
|
|
|
|
*
|
|
|
|
* @param string $name The name of the domain to register
|
|
|
|
* @param string $directory The directory where message catalogs can be found
|
|
|
|
*
|
2021-05-20 12:42:12 +02:00
|
|
|
* @return void
|
2014-01-29 16:25:08 +01:00
|
|
|
*/
|
|
|
|
public static function registerDomain($name, $directory)
|
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
/** @var GettextTranslator $translator */
|
|
|
|
$translator = StaticTranslator::$instance;
|
|
|
|
|
|
|
|
$translator->addTranslationDirectory($directory, $name);
|
2014-01-29 16:25:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the locale to use
|
|
|
|
*
|
|
|
|
* @param string $localeName The name of the locale to use
|
|
|
|
*
|
2021-05-20 12:42:12 +02:00
|
|
|
* @return void
|
2014-01-29 16:25:08 +01:00
|
|
|
*/
|
|
|
|
public static function setupLocale($localeName)
|
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
/** @var GettextTranslator $translator */
|
|
|
|
$translator = StaticTranslator::$instance;
|
2019-05-10 12:21:40 +02:00
|
|
|
|
2021-05-20 12:42:12 +02:00
|
|
|
$translator->setLocale($localeName);
|
2014-01-29 16:25:08 +01:00
|
|
|
}
|
2014-01-30 13:17:15 +01:00
|
|
|
|
2014-06-25 10:42:09 +02:00
|
|
|
/**
|
|
|
|
* Split and return the language code and country code of the given locale or the current locale
|
|
|
|
*
|
|
|
|
* @param string $locale The locale code to split, or null to split the current locale
|
|
|
|
*
|
2015-08-31 09:08:31 +02:00
|
|
|
* @return object An object with a 'language' and 'country' attribute
|
2014-06-25 10:42:09 +02:00
|
|
|
*/
|
|
|
|
public static function splitLocaleCode($locale = null)
|
2014-06-20 13:12:23 +02:00
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
/** @var GettextTranslator $translator */
|
|
|
|
$translator = StaticTranslator::$instance;
|
|
|
|
|
|
|
|
if ($locale === null) {
|
|
|
|
$locale = $translator->getLocale();
|
2014-06-25 10:42:09 +02:00
|
|
|
}
|
2014-06-20 13:12:23 +02:00
|
|
|
|
2021-05-20 12:42:12 +02:00
|
|
|
return (new Locale())->parseLocale($locale);
|
2014-06-20 13:12:23 +02:00
|
|
|
}
|
|
|
|
|
2014-01-30 13:17:15 +01:00
|
|
|
/**
|
|
|
|
* Return a list of all locale codes currently available in the known domains
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function getAvailableLocaleCodes()
|
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
/** @var GettextTranslator $translator */
|
|
|
|
$translator = StaticTranslator::$instance;
|
2014-07-07 09:04:01 +02:00
|
|
|
|
2021-05-20 12:42:12 +02:00
|
|
|
return $translator->listLocales();
|
2014-01-30 13:17:15 +01:00
|
|
|
}
|
2014-06-25 10:42:09 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the preferred locale based on the given HTTP header and the available translations
|
|
|
|
*
|
|
|
|
* @param string $header The HTTP "Accept-Language" header
|
|
|
|
*
|
|
|
|
* @return string The browser's preferred locale code
|
|
|
|
*/
|
|
|
|
public static function getPreferredLocaleCode($header)
|
|
|
|
{
|
2021-05-20 12:42:12 +02:00
|
|
|
/** @var GettextTranslator $translator */
|
|
|
|
$translator = StaticTranslator::$instance;
|
2014-06-25 10:42:09 +02:00
|
|
|
|
2021-05-20 12:42:12 +02:00
|
|
|
return (new Locale())->getPreferred($header, $translator->listLocales());
|
2014-06-25 10:42:09 +02:00
|
|
|
}
|
2014-01-29 16:25:08 +01:00
|
|
|
}
|