marshmallow / nova-advanced-image
An advanced image field for Nova with crop and resize.
Installs: 52 149
Dependents: 3
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 5
Open Issues: 4
Language:Vue
Requires
- php: ^8.0
- intervention/image: ^3.6
- laravel/nova: ^4.0|^5.0
- dev-master
- v2.2.0
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.2
- v2.0.1
- v2.0.0
- v1.x-dev
- v1.10.0
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.1
- v1.2.0
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- v0.1.1
- v0.1.0
- dev-dependabot/composer/intervention/image-tw-3.10
- dev-dependabot/github_actions/actions/checkout-4
- dev-dependabot/github_actions/overtrue/phplint-9.5
- dev-dependabot/npm_and_yarn/vue-loader-17.4.2
- dev-dependabot/npm_and_yarn/sass-loader-16.0.4
- dev-nova5
- dev-42-add-support-for-laravel-10
- dev-development
- dev-nova4
This package is auto-updated.
Last update: 2024-12-30 16:15:21 UTC
README
This package provides an advanced image field for Nova resources allowing you to upload, crop and resize any image. It uses Cropper.js with vue-cropperjs in the frontend and Intervention Image in the backend.
Requirements
This package requires one of the following libraries:
- GD Library >=2.0 (used by default)
- Imagick PHP extension >=6.5.7
See Intervention requirements for more details.
Installation
Install the package into a Laravel application with Nova using Composer:
composer require marshmallow/nova-advanced-image
If you want to use Imagick as the default image processing library, follow the Intervention documentation for Laravel. This will provide you with a new configuration file where you can specify the driver you want.
Usage
AdvancedImage
extends from File
so you can use any methods that File
implements. See the documentation here.
<?php namespace App\Nova; // ... use Marshmallow\AdvancedImage\AdvancedImage; class Post extends Resource { // ... public function fields(Request $request) { return [ // ... // Simple image upload AdvancedImage::make('photo'), // Show a cropbox with a free ratio AdvancedImage::make('photo')->croppable(), // Show a cropbox with a fixed ratio AdvancedImage::make('photo')->croppable(16/9), // Resize the image to a max width AdvancedImage::make('photo')->resize(1920), // Resize the image to a max height AdvancedImage::make('photo')->resize(null, 1080), // Show a cropbox and resize the image AdvancedImage::make('photo')->croppable()->resize(400, 300), // Override the image processing driver for this field only AdvancedImage::make('photo')->driver('imagick')->croppable(), // Store to AWS S3 AdvancedImage::make('photo')->disk('s3'), // Specify a custom subdirectory AdvancedImage::make('photo')->disk('s3')->path('image'), ]; } }
The resize
option uses Intervention Image resize()
with the upsize and aspect ratio constraints.
Security
If you discover any security related issues, please email stef@marshmallow.dev instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.