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

v1.3.0 2023-08-06 19:32 UTC

This package is auto-updated.

Last update: 2025-01-06 22:41:32 UTC


README

Imagic for Laravel Nova 4

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

Buy me a coffee

WEDO

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.