codewithdennis / filament-factory-action
This plugin adds a new feature to the Filament admin panel table, enabling easy generation of test records for your database tables using your Laravel Factory definitions.
Fund package maintenance!
CodeWithDennis
Requires
- php: ^8.1
- filament/tables: ^3.0
- illuminate/contracts: ^10.0|^11.0
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.9
- orchestra/testbench: ^8.0|^9.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
README
This plugin adds a new feature to the Filament admin panel table, enabling easy generation of test records for your database tables using your Laravel Factory definitions.
This plugin extends the standard Filament action, ensuring that you can continue to utilize all the methods that are typically available within the action class
Installation
You can install the package via composer:
composer require codewithdennis/filament-factory-action
Usage Example
Prior to utilizing this action, it is essential to ensure that you have set up a factory for your model.
class ProfileFactory extends Factory { public function definition(): array { return [ 'name' => fake()->company(), 'is_public' => rand(0, 1), ]; } }
Suppose you already possess a ProfileResource
within the Filament framework. You can integrate the action into the ListProfiles class, as demonstrated in the following example.
FactoryAction::make(),
use App\Filament\Resources\ProfileResource; use CodeWithDennis\FactoryAction\FactoryAction; use Filament\Actions; use Filament\Resources\Pages\ListRecords; class ListProfiles extends ListRecords { protected static string $resource = ProfileResource::class; protected function getHeaderActions(): array { return [ FactoryAction::make() ->color('danger') // ->slideOver() ->icon('heroicon-o-wrench'), Actions\CreateAction::make() ]; } }
You can create/attach relational records with the following example. Just make certain that these models also possess their respective factories
protected function getHeaderActions(): array { return [ FactoryAction::make() // If you want to create or create and attach you can do so using `hasMany` ->hasMany([Badge::class, Category::class]) // If you want to attach existing models you can do so using `belongsToMany` ->belongsToMany([Badge::class, Category::class]), ]; }
The default behavior is to hide the action in production environments, but you can override this by using your own logic:
->hidden(fn() => false)
Showcase
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.