vormkracht10 / filament-media-picker
This is my package filament-media-picker
Fund package maintenance!
vormkracht10
Requires
- php: ^8.1
- filament/filament: ^3.0
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.9
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^8.0
- pestphp/pest: ^2.1
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
This package is auto-updated.
Last update: 2025-01-20 07:14:16 UTC
README
Nice to meet you, we're Vormkracht10
Hi! We are a web development agency from Nijmegen in the Netherlands and we use Laravel for everything: advanced websites with a lot of bells and whitles and large web applications.
About the package
This package is a media picker and library for Filament. It allows you to easily add a media picker to your Filament forms and use it to select images, videos, and other media files from your media library. It also provides a media library that you can use to manage your media files.
Installation
You can install the package via composer:
composer require vormkracht10/filament-media-picker
You can publish and run the migrations with:
php artisan vendor:publish --tag="media-picker-migrations"
Note
When you are making use of tenancy, make sure to run the migrations after configuring the package using the config file. This will create the media table in your database with the correct columns.
You can publish the config file with:
php artisan vendor:publish --tag="media-picker-config"
This is the contents of the published config file:
return [ 'accepted_file_types' => [ 'image/jpeg', 'image/png', 'image/webp', 'image/svg+xml', 'application/pdf', ], 'directory' => 'media', 'disk' => env('FILAMENT_FILESYSTEM_DISK', 'public'), 'should_preserve_filenames' => false, 'should_register_navigation' => true, 'visibility' => 'public', // Tenancy 'is_tenant_aware' => true, 'tenant_ownership_relationship_name' => 'tenant', 'tenant_relationship' => 'tenant', // 'tenant_model' => \App\Models\Tenant::class, // Model and resource 'model' => \Vormkracht10\MediaPicker\Models\Media::class, // 'user_model' => \App\Models\User::class, 'resources' => [ 'label' => 'Media', 'plural_label' => 'Media', 'navigation_group' => null, 'navigation_label' => 'Media', 'navigation_icon' => 'heroicon-o-photo', 'navigation_sort' => null, 'navigation_count_badge' => false, 'resource' => \Vormkracht10\MediaPicker\Resources\MediaResource::class, ], ];
After publishing the config file and running the migrations you should add the following code to your PanelServiceProvider
to include the media picker in your Filament application:
use Filament\Support\Assets\Css; use Vormkracht10\MediaPicker\MediaPicker; use Filament\Support\Facades\FilamentAsset; public function panel(Panel $panel): Panel { // ... FilamentAsset::register([ Css::make('filament-media-picker', __DIR__ . '/../vendor/vormkracht10/filament-media-picker/resources/dist/filament-media-picker.css'), ], package: 'vormkracht10/filament-media-picker'); // ... return $panel ->plugins([ MediaPickerPlugin::make() ->configureTenant('site', Site::class), // Optional ]); }
Usage
Tenancy
If you are using tenancy, you can set the is_tenant_aware
config option to true
and set the tenant_ownership_relationship_name
and tenant_relationship
config options to the names of the relationships on the media model and the tenant model, respectively. You can also set the tenant_model
config option to the fully qualified class name of the tenant model.
File upload (with relationship)
If you want to be able to setup a relationship between a model and a media file, you can add the Vormkracht10\MediaPicker\Concerns\HasMedia
trait on the model to easily attach a media file to the model. You can then use the following methods to define the relationship:
$model->attachMedia($mediaUlid); // or with meta data $model->attachMedia($mediaUlid, [ 'position' => 1, 'meta' => ['description' => 'Profile picture'] ]);
Media Picker component
You can use the MediaPicker
component in your forms to add a media picker to your Filament forms. The MediaPicker
component is a FileUpload
field that respects the media-picker
config file.
use Vormkracht10\MediaPicker\Components\MediaPicker; MediaPicker::make('media'),
Handle record creation
To handle the creation of a record with a media file, you can use the Vormkracht10\MediaPicker\MediaPicker
class to handle the file upload and attach the media file to the record.
Creating resources
use Vormkracht10\MediaPicker\MediaPicker; protected function mutateFormDataBeforeCreate(array $data): array { unset($data['media']); // ... return $data; } protected function afterCreate(): void { // ... $media = MediaPicker::create($this->data['media']); foreach ($media as $value) { $this->getRecord()->attachMedia($value->ulid); } }
Editing resources
use Vormkracht10\MediaPicker\MediaPicker; protected function mutateFormDataBeforeFill(array $data): array { $data['media'] = $this->getRecord()->media->map(function ($media) { return 'media/' . $media->filename; })->toArray(); return $data; } protected function mutateFormDataBeforeSave(array $data): array { $media = MediaPicker::create($data['media']); unset($data['media']); foreach ($media as $value) { $this->getRecord()->attachMedia($value->ulid); } return $data; }
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
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.