Added langs array and fix update lang message

This commit is contained in:
Joseph Cohen 2015-01-14 15:49:38 -06:00
parent 99b5a77543
commit 9e0aa32818
4 changed files with 25 additions and 10 deletions

9
app/config/langs.php Normal file
View File

@ -0,0 +1,9 @@
<?php
return [
// Enabled langs
'de' => 'Deutsch',
'en' => 'English',
'fr' => 'Français',
'pt-BR' => 'Portuguese, Brazilian',
];

View File

@ -4,6 +4,7 @@ namespace CachetHQ\Cachet\Composers;
use DateTime; use DateTime;
use DateTimeZone; use DateTimeZone;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\View; use Illuminate\Support\Facades\View;
class TimezoneLocaleComposer class TimezoneLocaleComposer
@ -17,10 +18,12 @@ class TimezoneLocaleComposer
*/ */
public function compose(\Illuminate\View\View $view) public function compose(\Illuminate\View\View $view)
{ {
$langs = array_map(function ($lang) { $enabledLangs = Config::get('langs');
$langs = array_map(function ($lang) use ($enabledLangs) {
$locale = basename($lang); $locale = basename($lang);
return [$locale => ucwords(locale_get_display_name($locale, $locale))]; return [$locale => $enabledLangs[$locale]];
}, glob(app_path('lang').'/*')); }, glob(app_path('lang').'/*'));
$langs = call_user_func_array('array_merge', $langs); $langs = call_user_func_array('array_merge', $langs);

View File

@ -6,6 +6,7 @@ use CachetHQ\Cachet\Models\Setting;
use Exception; use Exception;
use GrahamCampbell\Binput\Facades\Binput; use GrahamCampbell\Binput\Facades\Binput;
use Illuminate\Routing\Controller; use Illuminate\Routing\Controller;
use Illuminate\Support\Facades\Lang;
use Illuminate\Support\Facades\Redirect; use Illuminate\Support\Facades\Redirect;
use Illuminate\Support\Facades\View; use Illuminate\Support\Facades\View;
@ -168,6 +169,8 @@ class DashSettingsController extends Controller
return Redirect::back()->with('errors', trans('dashboard.settings.edit.failure')); return Redirect::back()->with('errors', trans('dashboard.settings.edit.failure'));
} }
Lang::setLocale(Binput::get('app_locale'));
return Redirect::back()->with('success', trans('dashboard.settings.edit.success')); return Redirect::back()->with('success', trans('dashboard.settings.edit.success'));
} }
} }

View File

@ -3,9 +3,6 @@
namespace CachetHQ\Cachet\Providers; namespace CachetHQ\Cachet\Providers;
use CachetHQ\Cachet\Models\Setting; use CachetHQ\Cachet\Models\Setting;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Lang;
use Illuminate\Support\ServiceProvider; use Illuminate\Support\ServiceProvider;
class LoadConfigServiceProvider extends ServiceProvider class LoadConfigServiceProvider extends ServiceProvider
@ -17,15 +14,18 @@ class LoadConfigServiceProvider extends ServiceProvider
*/ */
public function boot() public function boot()
{ {
// // Get app custom configuration.
$appDomain = Setting::get('app_domain'); $appDomain = Setting::get('app_domain');
$appTimezone = Setting::get('app_timezone'); $appTimezone = Setting::get('app_timezone');
$appLocale = Setting::get('app_locale'); $appLocale = Setting::get('app_locale');
Config::set('app.url', $appDomain ?: Config::get('app.url')); // Override default app values.
Config::set('app.timezone', $appTimezone ?: Config::get('app.timezone')); $this->app->config->set('app.url', $appDomain ?: $this->app->config->get('app.url'));
Config::set('app.locale', $appLocale ?: Config::get('app.locale')); $this->app->config->set('app.timezone', $appTimezone ?: $this->app->config->get('app.timezone'));
Lang::setLocale($appLocale); $this->app->config->set('app.locale', $appLocale ?: $this->app->config->get('app.locale'));
// Set custom lang.
$this->app->translator->setLocale($appLocale);
} }
/** /**