2017-08-04 16:28:16 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Classe per gestire le traduzioni del progetto.
|
|
|
|
*
|
|
|
|
* @since 2.3
|
|
|
|
*/
|
|
|
|
class Translator extends Util\Singleton
|
|
|
|
{
|
|
|
|
/** @var Intl\Formatter Oggetto per la conversione di date e numeri nella lingua selezionata */
|
2017-09-19 16:20:44 +02:00
|
|
|
protected static $formatter;
|
2017-08-04 16:28:16 +02:00
|
|
|
|
|
|
|
/** @var Symfony\Component\Translation\Translator Oggetto dedicato alle traduzioni */
|
|
|
|
protected $translator;
|
|
|
|
|
|
|
|
/** @var array Lingue disponibili */
|
|
|
|
protected $locales = [];
|
|
|
|
/** @var string Lingua selezionata */
|
|
|
|
protected $locale;
|
|
|
|
|
|
|
|
public function __construct($default_locale = 'it', $fallback_locales = ['it'])
|
|
|
|
{
|
2017-09-10 18:29:51 +02:00
|
|
|
$translator = new Symfony\Component\Translation\Translator($default_locale);
|
|
|
|
$this->locale = $default_locale;
|
|
|
|
$translator->setFallbackLocales($fallback_locales);
|
2017-08-04 16:28:16 +02:00
|
|
|
|
2017-09-10 18:29:51 +02:00
|
|
|
// Imposta la classe per il caricamento
|
|
|
|
$translator->addLoader('default', new Intl\FileLoader());
|
2017-08-04 16:28:16 +02:00
|
|
|
|
2017-09-10 18:29:51 +02:00
|
|
|
$this->translator = $translator;
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ricerca e aggiunge le traduzioni presenti nei percorsi predefiniti (cartella locale sia nella root che nei diversi moduli).
|
|
|
|
*
|
|
|
|
* @param [type] $string
|
|
|
|
*/
|
|
|
|
public function addLocalePath($string)
|
|
|
|
{
|
|
|
|
$paths = glob($string);
|
|
|
|
foreach ($paths as $path) {
|
|
|
|
$this->addLocales($path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Aggiunge i contenuti della cartella specificata alle traduzioni disponibili.
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
*/
|
|
|
|
protected function addLocales($path)
|
|
|
|
{
|
2017-09-10 18:29:51 +02:00
|
|
|
// Individua i linguaggi disponibili
|
|
|
|
$dirs = glob($path.DIRECTORY_SEPARATOR.'*', GLOB_ONLYDIR);
|
|
|
|
foreach ($dirs as $dir) {
|
|
|
|
$this->addLocale(basename($dir));
|
|
|
|
}
|
2017-08-04 16:28:16 +02:00
|
|
|
|
2017-09-10 18:29:51 +02:00
|
|
|
// Aggiunge le singole traduzioni
|
|
|
|
foreach ($this->locales as $lang) {
|
|
|
|
$done = [];
|
2017-08-04 16:28:16 +02:00
|
|
|
|
2017-09-10 18:29:51 +02:00
|
|
|
$files = glob($path.DIRECTORY_SEPARATOR.$lang.DIRECTORY_SEPARATOR.'*.*');
|
|
|
|
foreach ($files as $file) {
|
|
|
|
if (!in_array(basename($file), $done)) {
|
|
|
|
$this->translator->addResource('default', $file, $lang);
|
2017-08-04 16:28:16 +02:00
|
|
|
|
2017-09-10 18:29:51 +02:00
|
|
|
$done[] = basename($file);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Aggiunge il linguaggio indicato all'elenco di quelli disponibili.
|
|
|
|
*
|
|
|
|
* @param string $language
|
|
|
|
*/
|
|
|
|
protected function addLocale($language)
|
|
|
|
{
|
|
|
|
if (!$this->isLocaleAvailable($language)) {
|
|
|
|
$this->locales[] = $language;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restituisce l'elenco dei linguaggi disponibili.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getAvailableLocales()
|
|
|
|
{
|
|
|
|
return $this->locales;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Controlla se il linguaggio indicato è disponibile.
|
|
|
|
*
|
|
|
|
* @param string $language
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isLocaleAvailable($language)
|
|
|
|
{
|
|
|
|
return in_array($language, $this->getAvailableLocales());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Imposta il linguaggio in utilizzo.
|
|
|
|
*
|
|
|
|
* @param string $locale
|
|
|
|
*/
|
2017-09-19 16:20:44 +02:00
|
|
|
public function setLocale($locale, $formatter = [])
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
|
|
|
if (!empty($locale) && $this->isLocaleAvailable($locale)) {
|
2017-09-10 18:29:51 +02:00
|
|
|
$this->translator->setLocale($locale);
|
2017-08-04 16:28:16 +02:00
|
|
|
$this->locale = $locale;
|
2017-09-19 16:20:44 +02:00
|
|
|
|
|
|
|
self::$formatter = new Intl\Formatter(
|
|
|
|
$this->locale,
|
|
|
|
empty($formatter['timestamp']) ? 'd/m/Y H:i' : $formatter['timestamp'],
|
|
|
|
empty($formatter['date']) ? 'd/m/Y' : $formatter['date'],
|
2017-09-20 12:14:33 +02:00
|
|
|
empty($formatter['time']) ? 'H:i' : $formatter['time'],
|
|
|
|
empty($formatter['number']) ? [
|
|
|
|
'decimals' => ',',
|
|
|
|
'thousands' => '.',
|
|
|
|
] : $formatter['number']
|
2017-09-19 16:20:44 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
self::$formatter->setPrecision(Settings::get('Cifre decimali per importi'));
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restituisce il linguaggio attualmente in utilizzo.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getCurrentLocale()
|
|
|
|
{
|
|
|
|
return $this->locale;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restituisce l'oggetto responsabile della gestione delle traduzioni.
|
|
|
|
*
|
|
|
|
* @return Symfony\Component\Translation\Translator
|
|
|
|
*/
|
|
|
|
public function getTranslator()
|
|
|
|
{
|
|
|
|
return $this->translator;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restituisce la traduzione richiesta.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
* @param string $parameters
|
|
|
|
* @param string $domain
|
|
|
|
* @param string $locale
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-09-10 14:35:41 +02:00
|
|
|
public static function translate($string, $parameters = [], $operations = [])
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
2017-09-10 18:29:51 +02:00
|
|
|
$result = self::getInstance()->getTranslator()->trans($string, $parameters);
|
2017-09-10 14:35:41 +02:00
|
|
|
|
|
|
|
// Operazioni aggiuntive sul risultato
|
|
|
|
if (!empty($operations)) {
|
|
|
|
$result = new Stringy\Stringy($result);
|
|
|
|
|
|
|
|
if (!empty($operations['upper'])) {
|
|
|
|
$result = $result->toUpperCase();
|
|
|
|
} elseif (!empty($operations['lower'])) {
|
|
|
|
$result = $result->toLowerCase();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (string) $result;
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Restituisce il formato locale della data.
|
|
|
|
*
|
|
|
|
* @return Intl\Formatter
|
|
|
|
*/
|
2017-09-19 16:20:44 +02:00
|
|
|
public static function getFormatter()
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::$formatter;
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte il numero dalla formattazione locale a quella inglese.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function numberToEnglish($string)
|
|
|
|
{
|
2017-09-21 10:01:07 +02:00
|
|
|
return self::getFormatter()->parseNumber($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte il numero dalla formattazione inglese a quella locale.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
* @param mixed $decimals
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-09-19 16:20:44 +02:00
|
|
|
public static function numberToLocale($string, $decimals = null)
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
|
|
|
$string = !isset($string) ? 0 : $string;
|
|
|
|
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->formatNumber($string, $decimals);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte la data dalla formattazione locale a quella inglese.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function dateToEnglish($string)
|
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->parseDate($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte la data dalla formattazione inglese a quella locale.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
* @param string $fail
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-09-19 16:20:44 +02:00
|
|
|
public static function dateToLocale($string)
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->formatDate($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte la data dalla formattazione locale a quella inglese.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function timeToEnglish($string)
|
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->parseTime($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte la data dalla formattazione inglese a quella locale.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
* @param string $fail
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-09-19 16:20:44 +02:00
|
|
|
public static function timeToLocale($string)
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->formatTime($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte un timestamp dalla formattazione locale a quella inglese.
|
|
|
|
*
|
|
|
|
* @param string $timestamp
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function timestampToEnglish($string)
|
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->parseTimestamp($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converte un timestamp dalla formattazione inglese a quella locale.
|
|
|
|
*
|
|
|
|
* @param string $timestamp
|
|
|
|
* @param string $fail
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2017-09-19 16:20:44 +02:00
|
|
|
public static function timestampToLocale($string)
|
2017-08-04 16:28:16 +02:00
|
|
|
{
|
2017-09-19 16:20:44 +02:00
|
|
|
return self::getFormatter()->formatTimestamp($string);
|
2017-08-04 16:28:16 +02:00
|
|
|
}
|
|
|
|
}
|