This package extension provides extra features for the spatie/laravel-medialibrary package.
Found this package helpful? Please consider supporting my work!
This package extension will follow the base package major versions but may be a bit stricter about compatibility constraints.
Laravel | Original package | PHP | Package |
---|---|---|---|
^9.0 | ^10.0 | ^10.7.9 | 8.1.* | 8.2.* | ^10.2 |
^9.0 | ^10.6 | ^8.1 | ^8.2 | ^10.1 |
^9.0 | ^10.0 | ^8.0 | ^8.1 | ^10.0 |
^7.0 | ^8.0 | ^9.0 | ^7.4 | ^8.0 | ^9.1 |
^7.0 | ^8.0 | ^9.0 | ^7.4 | ^9.0 |
^7.0 | ^8.0 | ^8.7.1 | ^7.4 | ^8.1 |
^6.0 | ^7.0 | ^8.0 | ^7.4 | ^8.0 |
^6.0 | ^7.0 | X | ^7.4 | ^8.0 |
^5.8 | ^6.0 | ^7.0 | X | ^7.2 | ^7.18 |
^5.5 | ^5.6 | ^5.7 | ^5.8 | ^6.0 | X | ^7.2 | ^7.12 |
^5.5 | ^5.6 | ^5.7 | ^5.8 | X | ^7.2 | ^7.11 |
- Installation
- Documentation
- Translations
- Extension features
- Testing
- Changelog
- Contributing
- Security
- Credits
- Licence
First, be sure to follow the base package installation instructions:
- https://github.com/spatie/laravel-medialibrary#installation
- https://docs.spatie.be/laravel-medialibrary/v8/installation-setup
Then, install the extension via composer:
composer require okipa/laravel-medialibrary-ext
Finally, implement the ExtendsMediaAbilities
trait to be able to use the extension features in addition of the base package ones.
use Illuminate\Database\Eloquent\Model;
use Okipa\MediaLibraryExt\ExtendsMediaAbilities;
use Spatie\MediaLibrary\HasMedia;
use Spatie\MediaLibrary\InteractsWithMedia;
class Page extends Model implements HasMedia
{
use InteractsWithMedia;
use ExtendsMediaAbilities;
// ...
}
Find the complete documentation of the base package here: https://docs.spatie.be/laravel-medialibrary/v8/introduction.
All captions are translatable.
See how to translate them on the Laravel official documentation: https://laravel.com/docs/localization#using-translation-strings-as-keys.
Here is the list of the sentences available for translation:
Min. width: :width px.
Min. height: :height px.
{1}Accepted type: :types.|[2,*]Accepted types: :types.
Max. file size: :size Mb.
Declaring your media validation rules like this:
// In your user storing form request for example
public function rules()
{
return [
'avatar' => (new User)->getMediaValidationRules('avatar'),
// your other validation rules
];
}
Will generate:
// Example
['mimetypes:image/jpeg,image/png', 'mimes:jpg,jpeg,jpe,png', 'dimensions:min_width=60,min_height=20', 'max:5000'];
->getMediaValidationRules(string $collectionName): array
: returns all the validation rules for the given collection.->getMediaMimesValidationRules(string $collectionName): string
: returns only the mimes validation rules for the given collection.->getMediaMimeTypesValidationRules(string $collectionName): string
: returns only the mime types validation rules for the given collection.->getMediaDimensionValidationRules(string $collectionName): string
: returns only the dimension validation rules for the given collection.->getMediaSizeValidationRule(): string
: returns only the max file size validation rule set from the base packagemedia-library.max_file_size
configuration value.
Adding a constraint caption under a file input:
<!-- In your HTML form -->
<label for="avatar">Choose a profile picture:</label>
<input type="file" id="avatar" name="avatar" value="{{ $user->getFirstMedia('avatar')->name }}">
<small>{{ $user->getMediaCaption('avatar') }}</small>
Will generate:
<!-- Example -->
Min. width: 150 px. Min. height: 70 px. Accepted types: jpg, jpeg, jpe, png. Max file size: 5Mb.
getMediaCaption(string $collectionName): string
: returns a complete caption for the given collection.getMediaDimensionsCaption(string $collectionName): string
: returns only the dimensions caption for the given collection.getMediaMimeTypesCaption(string $collectionName): string
: returns only the mime types caption for the given collection.getMediaSizeCaption(): string
: returns only the config max file size caption only.
In order to avoid careless mistakes when using public methods that are requiring a string $collectionName
argument provided by this extension, an Okipa\MediaLibraryExt\Exceptions\CollectionNotFound
exception will be thrown when the given collection name is not found in the targeted model.
composer test
Please see CHANGELOG for more information about what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email arthur.lorent@gmail.com instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.