The Laravel Filament Chained Translation Manager allows you to easily edit the translations of your current Laravel environment. This translation manager uses the Laravel Chained Translator, that enables you to override the default translations with translations for a specific environment, e.g. a content manager can independently edit and override the translation files on the production environment from the translations provided by the developers.
Typically, at some point during the development phase, a content manager wants to translate or finetune the translation strings added by developers. This often results in merge and versioning issues, when developers and content managers are working on the translation files at the same time.
The Chained Translator package allows translations created by developers to exist separately from translations edited by the content manager in separate lang directories. The library merges the translations of both language directories, where the translations of the content manager (the custom translations) override those of the developer (the default translations). Check the documentation of the Laravel Chained Translator for more info.
There is also a Laravel Nova Chained Translation Manager of this package.
This tool does not provide features to add new translation keys, because our target users are translators and content managers, and we want to avoid that they add unnecessary translation keys.
Note For Filament 2.x use v1.x version
composer require statikbe/laravel-filament-chained-translation-manager
public function panel(Panel $panel): Panel{ return $panel ->plugins([ \Statikbe\FilamentTranslationManager\FilamentChainedTranslationManagerPlugin::make(), ]);}
content
array of the generated tailwind.config.js
file for the Filament theme:"./vendor/statikbe/laravel-filament-chained-translation-manager/**/*.blade.php",
npm run build
config
file then setup your configuration:php artisan vendor:publish --tag="filament-translation-manager-config"
You can configure the custom language directory name and extend or finetune the service provider of the Laravel Chained Translator. Have a look at the configuration options of the Laravel Chained Translator library.
There are two ways to change the supported locales.
Set up the supported locales using the configuration. By default, it will fallback to the locale and fallback locale. However, you can customize the configuration to include additional locales as follows:
'locales' => [ 'en', 'fr',],
If your application already has a config that declares your locales than you are able to set the supported locales in any service provider.
Create a new one or use the app/Providers/AppServiceProvider.php
and set the supported locales as an array in the boot function as follows:
use Statikbe\FilamentTranslationManager\FilamentTranslationManager;Â public function boot(){ FilamentTranslationManager::setLocales(['en', 'nl']);}
You can restrict access to the Translation Manager by configuring the Gate variable.
'gate' => 'view-filament-translation-manager',
You can choose to exclude specific groups of translations from appearing in Filament. Create an array with the keys that you wish to ignore:
'ignore_groups' => [ 'auth',],
You can customize the navigation icon by configuring the navigation-icon
variable
'navigation_icon' => 'heroicon-o-language',
Or you can replace the icon with your own custom icon set, by registering a different icon for this icon:
filament-chained-translation-manager::nav-icon
.
The library creates a new directory for the new translations, see Laravel Chained Translator. Check the configuration options of the Laravel Chained Translator package to change this.
Additionally, please note that the Translation Manager is automatically included in the Filament menu.
You can combine the custom translations of the current environment with the default translation files, by running the command provided by the Laravel Chained Translator.
Please see UPGRADING for details.
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.
At Statik we believe in business as a force for good, resulting in our BCorp certification. We design and develop innovative and interactive products, platforms and tools that make users' daily lives easier. Our full-stack developers have profound experience with Laravel & Javascript.