A custom Markdown Field for Nova with image upload support
- For Laravel Nova ^4.0
- Image upload
- Accepts Drag & Drop / Copy & Paste
composer require ardenthq/nova-enhanced-markdown
- Add the
EnhancedMarkdown
field to your Nova Resource.
<?php
namespace App\Nova;
use Laravel\Nova\Http\Requests\NovaRequest;
use Laravel\Nova\Resource;
use Ardenthq\EnhancedMarkdown\EnhancedMarkdown;
final class ResourceName extends Resource
{
// ....
public function fields(NovaRequest $request)
{
return [
// ....
EnhancedMarkdown::make('body'),
// ...
];
}
// ...
}
- By default, this package only validates the attachment as an actual file. If you require more rules (let's say that you only want to accept images), define the rules with the new
attachmentRules
method.
EnhancedMarkdown::make('Content', 'content')
->attachmentRules('dimensions:min_width=20,min_height:20', 'image'),
- In some cases, you may want to parse the file before storing it (for example, apply some optimizations). To do that, you can add a callback by using the
parseFile
method.
EnhancedMarkdown::make('Content', 'content')
->parseFile(function (EnhancedMarkdown $field, UploadedFile $file) {
$image = \Spatie\Image\Image::load($file->getPathname());
$image->fit(\Spatie\Image\Manipulations::FIT_MAX, 100, 100);
$image->save();
});
If needed, you can also return a new instance of the file, that instance is the one that is going to be stored.
Important: You need to return an instance of Illuminate\Http\UploadedFile
, Illuminate\Http\File
or a string
.
EnhancedMarkdown::make('Content', 'content')
->parseFile(function (EnhancedMarkdown $field, UploadedFile $file) {
return new File('some/path');
});
- The files are stored by default with
/
as a path and usingpublic
storage disk. You can change the path and the storage disk with thedisk
andpath
methods:
EnhancedMarkdown::make('Content', 'content')
->disk('s3')
->path('articles')
- Run
yarn nova:install
andyarn install
to install all the necessary dependencies for compiling the view components. - Run
yarn run dev
(oryarn run watch
) while making changes to the components in your local environment. - If you change the vue components, ensure to compile for production before making a PR.
- Run
yarn nova:install
andyarn install
to install all the necessary dependencies for compiling the view components. - Run
yarn run production
.
composer analyse
composer refactor
composer format
composer test
If you discover a security vulnerability within this package, please send an e-mail to [email protected]. All security vulnerabilities will be promptly addressed.
This project exists thanks to all the people who contribute.