74 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
		
		
			
		
	
	
			74 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
| 
								 | 
							
								<?php namespace BookStack\Translation;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class Translator extends \Illuminate\Translation\Translator
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Mapping of locales to their base locales
							 | 
						||
| 
								 | 
							
								     * @var array
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected $baseLocaleMap = [
							 | 
						||
| 
								 | 
							
								        'de_informal' => 'de',
							 | 
						||
| 
								 | 
							
								    ];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Get the translation for a given key.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param  string  $key
							 | 
						||
| 
								 | 
							
								     * @param  array   $replace
							 | 
						||
| 
								 | 
							
								     * @param  string  $locale
							 | 
						||
| 
								 | 
							
								     * @return string|array|null
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function trans($key, array $replace = [], $locale = null)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $translation = $this->get($key, $replace, $locale);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (is_array($translation)) {
							 | 
						||
| 
								 | 
							
								            $translation = $this->mergeBackupTranslations($translation, $key, $locale);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return $translation;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Merge the fallback translations, and base translations if existing,
							 | 
						||
| 
								 | 
							
								     * into the provided core key => value array of translations content.
							 | 
						||
| 
								 | 
							
								     * @param array $translationArray
							 | 
						||
| 
								 | 
							
								     * @param string $key
							 | 
						||
| 
								 | 
							
								     * @param null $locale
							 | 
						||
| 
								 | 
							
								     * @return array
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function mergeBackupTranslations(array $translationArray, string $key, $locale = null)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $fallback = $this->get($key, [], $this->fallback);
							 | 
						||
| 
								 | 
							
								        $baseLocale = $this->getBaseLocale($locale ?? $this->locale);
							 | 
						||
| 
								 | 
							
								        $baseTranslations = $baseLocale ? $this->get($key, [], $baseLocale) : [];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return array_replace_recursive($fallback, $baseTranslations, $translationArray);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Get the array of locales to be checked.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param  string|null  $locale
							 | 
						||
| 
								 | 
							
								     * @return array
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function localeArray($locale)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $primaryLocale = $locale ?: $this->locale;
							 | 
						||
| 
								 | 
							
								        return array_filter([$primaryLocale, $this->getBaseLocale($primaryLocale), $this->fallback]);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Get the locale to extend for the given locale.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param string $locale
							 | 
						||
| 
								 | 
							
								     * @return string|null
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function getBaseLocale($locale)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return $this->baseLocaleMap[$locale] ?? null;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}
							 |