ayvazyan10 / nova-imagic
Imagic is a Laravel Nova field package that allows for image manipulation capabilities, such as cropping, resizing, quality adjustment, and WebP conversion. It utilizes the powerful Intervention Image class for image manipulation.
Installs: 3 597
Dependents: 1
Suggesters: 0
Security: 0
Stars: 14
Watchers: 1
Forks: 2
Open Issues: 4
Language:Vue
Requires
- php: ^7.1|^8.0
- intervention/image: ^2.7
- laravel/nova: ^4.0
Suggests
- ext-exif: Install the exif extension to orientate images automatically.
- ext-gd: Install the GD extension to process images using GD.
- ext-imagick: Install the Imagick extension to process image using ImageMagick.
README
Imagic is a Laravel Nova field package that allows for image manipulation capabilities, such as cropping, resizing, quality adjustment, and WebP conversion. It utilizes the powerful Intervention Image class for image manipulation. The purpose of this package is to optimize images for web usage by converting them to the WebP format, which provides superior compression and faster load times.
Advanced Image Manipulation Made Easy with Images Magic
✅ Single/Multiple Uploads
✅ Cropping
✅ Resizing
✅ Fitting
✅ Quality Control
✅ WebP Conversion
✅ Watermarking
✅ Custom Directories
Requirements
- PHP (^7.1 or higher)
- Laravel Nova (^4.0 or higher)
🚀 Installation
Install the package via Composer.
composer require ayvazyan10/nova-imagic
📚 Usage
Here is an example of how to use Imagic in your Laravel Nova application: In your Laravel Nova resources, use the Imagic field:
use Ayvazyan10\Imagic\Imagic; public function fields(Request $request) { return [ // ... Imagic::make('Image', 'image'), // ... ]; }
⚡ All Methods
Imagic::make('Image') ->multiple() ->crop($width, $height, $left = 0, $top = 0) ->resize($width, $height) ->fit($width, $height) ->widen($width) ->quality($quality) ->disk($path) ->directory($path) ->convert($convert = true) ->watermark($path, $position = 'bottom-right', $x = 0, $y = 0);
📖 Examples
Below are some examples in different scenarios.
- Multiple Images
To enable multiple image uploads, use the multiple() method. Note that when you use the multiple() method, your database column should be of type text, longtext, or json to store all images in a JSON format. Additionally, you will have the ability to sort uploaded images by drag and drop.
Imagic::make('Images')->multiple(),
- Cropping
To crop images, use the crop() method:
- x (optional) X-Coordinate of the top-left corner if the rectangular cutout. By default the rectangular part will be centered on the current image.
- y (optional) Y-Coordinate of the top-left corner if the rectangular cutout. By default the rectangular part will be centered on the current image.
Imagic::make('Image')->crop($width, $height, $x, $y),
- Resizing
To resize images, use the resize() method:
Imagic::make('Image')->resize($width = int|null, $height = int|null),
- Widen resizing by width
Specify the desired (only - width) for image resizing.
- The height will be automatically adjusted to maintain the aspect ratio.
Imagic::make('Image')->widen($width = int),
- Quality
To adjust the image quality, use the quality() method: default is 90
Imagic::make('Image')->quality(90),
- WebP Conversion
To convert images to WebP format, use the convert() method:
By default, the images will be converted to WebP format. To disable conversion, pass false to the convert() method:
Imagic::make('Image')->convert(false),
- Fit
You can use the fit() method when defining the Imagic field in your Nova resource:
Imagic::make('Image')->fit($width, $height),
- Field with watermark
Replace the /path/to/watermark.png with the actual path to your watermark image.
This will add the watermark to the image with the specified path, position, and offset (15x15 pixels from the bottom-right corner in this example).
Remember to import the Imagic class at the top of your Nova resource file:
Imagic::make('Image')->watermark('/path/to/watermark.png', 'bottom-right', 15, 15),
- Specified disk
Here is an example of how to use it:
Imagic::make('Image')->disk('public')
Caution: The disk is not working with custom directories and will throw an error.
- Directory Customization
BY DEFAULT - Imagic uses this structure: /storage/imagic/year/month/day/image_name.webp
The Imagic class includes a directory() method that allows you to specify a custom directory path for your image uploads. This allows for more flexibility in managing the location of your image files.
To use this feature, call the directory() method when creating an Imagic field and provide it with your custom directory path as an argument. This path should be a string, and should not start or end with a /.
Here is an example of how to use it:
Imagic::make('Image')->directory('your/custom/directory')
In this example, any images uploaded through this field will be saved in your/custom/directory.
Caution: The provided directory path should not start or end with a /. If it does, an InvalidArgumentException will be thrown. Make sure your directory path is correctly formatted when using this feature.
For example, the following code would throw an exception:
// This will throw an exception because the directory path starts with a '/' // Directory structure should not start or end with a slash. Only in the middle. Imagic::make('Image') ->directory('/invalid/directory/path')
Contributing
Please see contributing.md for details and a todolist.
Security
If you discover any security related issues, please email ayvazyan403@gmail.com instead of using the issue tracker.
Author
License
MIT. Please see the license file for more information.