rato-guras/media-library
最新稳定版本:v1.0.0
Composer 安装命令:
composer require rato-guras/media-library
包简介
Reusable Laravel media library extracted from production app workflows.
README 文档
README
A standalone, reusable Laravel media library package with upload, browser, picker, thumbnail, and model-attachment support.
Requirements
- PHP: ^8.1
- Laravel: 10.x, 11.x, 12.x
- Intervention Image: ^3.9
Installation
composer require rato-guras/media-library php artisan media-library:install php artisan migrate
Features
- Upload image, document, audio, video, and generic files
- Optional image optimization pipeline (WebP conversion)
- Thumbnail generation for images
- Folder-aware media organization
- Media browser/grid endpoints and Blade UI
- Reusable Blade media picker component
- URL import endpoint
- Soft delete + restore + force delete behavior
- Polymorphic model attachment via
HasMedia
Auto Discovery
The package is auto-discovered by Laravel via composer.json:
- Provider:
RatoGuras\\MediaLibrary\\MediaLibraryServiceProvider - Facade alias:
MediaLibrary
Configuration
Publish config with install command or manually:
php artisan vendor:publish --tag=media-library-config
Config file: config/media-library.php
Key options:
diskroute_prefixroute_middlewareupload_directoryimage_directorythumbnail_directorydocument_directoryaudio_directoryvideo_directoryfile_directorymax_file_sizeallowed_mime_typesimage_drivercreate_thumbnailsthumbnail_widththumbnail_heightconvert_images_to_webp
Routes
All routes are prefixed by config('media-library.route_prefix') and use middleware from config('media-library.route_middleware').
Named routes:
media-library.indexmedia-library.gridmedia-library.pickermedia-library.uploadmedia-library.upload-from-urlmedia-library.folder.createmedia-library.folder.deletemedia-library.delete-by-collectionmedia-library.movemedia-library.restoremedia-library.updatemedia-library.destroy
Blade Component
Default alias: <x-media-picker />
Example:
<x-media-picker modalId="post-cover-picker" title="Select or Upload Cover" :allowMultiple="false" :allowUpload="true" :allowView="true" triggerSelector=".open-media-picker" onSelect="onCoverSelected" inputTarget="#cover_media_id" collection="cover" />
Model Attachment
Use the trait:
use Illuminate\Database\Eloquent\Model; use RatoGuras\MediaLibrary\Traits\HasMedia; class Post extends Model { use HasMedia; }
Usage:
$post->attachMediaFromRequest('cover_image', ['collection' => 'cover']); $all = $post->getMedia('cover'); $first = $post->getFirstMedia('cover'); $post->deleteMedia($mediaId); $post->clearMedia('cover');
Image Driver Fallback
- Set
media-library.image_driver=imagickto prefer Imagick. - If Imagick is unavailable, the package automatically falls back to GD.
- Default driver is GD for broad compatibility (including Windows).
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 7
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-24