okipa/laravel-medialibrary-ext 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

okipa/laravel-medialibrary-ext

Composer 安装命令:

composer require okipa/laravel-medialibrary-ext

包简介

Extra features for spatie/laravel-medialibrary package.

README 文档

README

Laravel Medialibrary Extension

Latest Stable Version Total Downloads Build Status Coverage Status License: MIT

This package extension provides extra features for the spatie/laravel-medialibrary package.

Found this package helpful? Please consider supporting my work!

Donate Donate

Compatibility

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

Upgrade guide

Table of contents

Installation

First, be sure to follow the base package installation instructions:

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;

	// ...
}

Documentation

Find the complete documentation of the base package here: https://docs.spatie.be/laravel-medialibrary/v8/introduction.

Translations

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.

Extension features

Media validation rules

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'];

Available public methods:

  • ->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 package media-library.max_file_size configuration value.

Media caption

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.

Available public methods:

  • 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.

Exceptions

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.

Testing

composer test

Changelog

Please see CHANGELOG for more information about what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email arthur.lorent@gmail.com instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 11.24k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 10
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 10
  • Watchers: 1
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2019-08-27

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固