ambengers/eloquent-pdf

Laravel package for creating PDF files with Eloquent ORM dependencies.

Installs: 585

Dependents: 0

Suggesters: 0

Security: 0

Stars: 21

Watchers: 2

Forks: 4

Open Issues: 0

pkg:composer/ambengers/eloquent-pdf

5.0 2023-10-27 23:03 UTC

This package is auto-updated.

Last update: 2025-10-05 07:07:39 UTC


README

This package provides an elegant way to generate PDF with Eloquent Models. Uses Laravel Snappy to generate PDF and Laravel Medialibrary to associate PDF as model media.

CircleCI StyleCI

Spatie Media Library Version Compatibility

Version Medialibrary
v1.* ~ 7.20
v2.* ^ 8.0
v3.* ^ 9.0
v4.* ^ 10.0
v5.* ^ 10.0

Installation

Via Composer

$ composer require ambengers/eloquent-pdf

Optionally, you can publish the config file by running the following command.

php artisan vendor:publish --tag=eloquent-pdf-config

Usage

Eloquent PDF class

You can generate your Eloquent PDF class using the command.

$ php artisan make:eloquent-pdf PostPdf

By default, the class will be located at App\Pdf namespace. You can customize this in config file.

Your Eloquent PDF class will contain 2 methods:

  • getData() provides the data to be used on the view
  • getView() the name of the view file as pdf template
namespace App\Pdf;

class PostPdf extends AbstractEloquentPdf
{
    public function getData() : array
    {
        return [
            'title' => $this->model->title,
            'body'  => $this->model->body,
        ];
    }

    public function getView() : string
    {
        return 'posts.pdf';
    }
}

You can now use the Eloquent PDF class from your controller (or anywhere in your application).

Downloading PDF

return app(PostPdf::class)
    ->model($post)
    ->download()
    ->handle();

Print Preview PDF

return app(PostPdf::class)
    ->model($post)
    ->stream()
    ->handle();

Eloquent PDF with Medialibrary

This package also offers an elegant way to associate PDF file to the Eloquent Model using Medialibrary package. To do that, you will need to use a trait on your Eloquent PDF class.

use Ambengers\EloquentPdf\InteractsWithMediaLibrary;

class PostPdf extends AbstractEloquentPdf
{
    use InteractsWithMediaLibrary;
}

Then on your controller, much like how you'd do on medialibrary, just provide the collection name in which the PDF file will be associated with.

return app(PostPdf::class)
    ->model($post)
    ->toMediaCollection('reports')
    ->handle();

For additional convenience you can also chain other medialibrary methods.

return app(PostPdf::class)
    ->model($post)
    ->toMediaCollection('reports')
    ->withCustomProperties(['foo' => 'bar'])
    ->withAttributes(['creator_id' => auth()->id()])
    ->handle();

Behind the scenes, Eloquent PDF will forward these method calls to the medialibrary FileAdder::class so you can further take advantage of its features.

Customizations

If you need further customizations such as changing the default PDF filename, extension or setting PDF options, you can override some methods from your Eloquent PDF class.

namespace App\Pdf;

class PostPdf extends AbstractEloquentPdf
{
    public function getOrientation(): string
    {
        return 'landscape';
    }

    public function getOptions(): array
    {
        return [
            'footer-right'     => 'Right footer text goes here!',
            'footer-font-size' => 8,
            'encoding'         => 'UTF-8',
        ];
    }

    public function getFilename(): string
    {
        return 'new-file-name';
    }

    public function getExtension(): string
    {
        return 'odt';
    }
}

Alternatively, if you want to only customize during runtime, you can chain some setter methods when you call your Eloquent PDF class.

return app(PostPdf::class)
    ->model($post)
    ->orientation('landscape')
    ->options(['footer-font-size' => 8])
    ->filename('some-cool-filename')
    ->toMediaCollection('reports')
    ->handle();

Security

If you discover any security related issues, please email author email instead of using the issue tracker.

License

Please see the license file for more information.