alareqi / filament-translatable-fields
This package adds a way to interact with alareqi/translatable-fields in Filament.
Requires
- php: ^8.0
- filament/filament: ^3.2
- laravel/framework: ^10.0|^11.0
- spatie/laravel-package-tools: ^1.16
- spatie/laravel-translatable: ^6.6
README
This package adds a way to make all filament fields translatable.
It uses the spatie/laravel-translatable
package in the background.
Installation
You can install the package via composer:
composer require alareqi/filament-translatable-fields
Add the plugin to your desired Filament panel:
use Alareqi\FilamentTranslatableFields\FilamentTranslatableFieldsPlugin; class FilamentPanelProvider extends PanelProvider { public function panel(Panel $panel): Panel { return $panel // ... ->plugins([ FilamentTranslatableFieldsPlugin::make(), ]); } }
You can specify the supported locales:
use Alareqi\FilamentTranslatableFields\FilamentTranslatableFieldsPlugin; class FilamentPanelProvider extends PanelProvider { public function panel(Panel $panel): Panel { return $panel // ... ->plugins([ FilamentTranslatableFieldsPlugin::make() ->supportedLocales([ 'en' => 'English', 'ar' => 'العربية', ]), ]); } }
By default, the package will use the app.locale
if you don't specify the locales.
Usage
You can simply add ->translatable()
to any field to make it translatable.
use Filament\Forms\Components\TextInput; TextInput::make('name') ->label('Name') ->translatable(),
Overwrite locales
If you want to overwrite the locales on a specific field you can set the locales through the second parameter of the ->translatable()
function.
use Filament\Forms\Components\TextInput; TextInput::make('name') ->label('Name') ->translatable(true, ['en' => 'English', 'ar' => 'العربية', 'fr' => 'French']),
Good to know
This package will substitute the original field with a Filament\Forms\Components\Tabs
component. This component will render the original field for each locale.
All chained methods you add before calling ->translatable()
will be applied to the original field.
All chained methods you add after calling ->translatable()
will be applied to the Filament\Forms\Components\Tabs
component.
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.