traincase / laravel-pdf-tinker
Live tinkering with HTML templates for conversion to PDF.
Installs: 24
Dependents: 0
Suggesters: 0
Security: 0
Stars: 44
Watchers: 4
Forks: 4
Open Issues: 0
Language:Blade
Requires
- php: ^8.3
- ext-json: *
- laravel/framework: ^11.0
- league/flysystem: ^3.0
- traincase/html-to-pdf-tinker: ^2.0
Requires (Dev)
- larapack/dd: ^1.1
- orchestra/testbench-dusk: ^9.8
- phpunit/phpunit: ^11.0
README
This package is meant as a tool for local development. Do not include this package in your production build.
Laravel PDF Tinker gives you a quick interface to debug and fiddle with the creation of HTML templates that will be converted into PDF's.
If you're one of those guys that frequently has to create custom templates for every client (order confirmations, goods deliveries, invoices etc.) this package is for you.
Installation
Since this package is only meant for during local development install this package as a development dependency.
composer require traincase/laravel-pdf-tinker --dev
The package will automatically register it's service provider, if you opted out of auto-discovery add something along the lines of the following to a registered service provider (for example the AppServiceProvider
):
// Put this inside the 'register' method if ($this->app->isLocal()) { $this->register(\Traincase\LaravelPdfTinker\PdfTinkerServiceProvider::class); }
Don't forget to check the drivers section to see if the driver you're planning to use requires any additional set-up.
Usage
You can find most options straight in the interface of the playground. Chances are high you don't have to edit the configuration. Nevertheless, there are a few things you can configure.
Configuration
Route prefix
The service provider will register a few routes necessary to set up and run the playground.
By default the routes are all prefixed with vendor/laravel-pdf-tinker
.
This means the playground is available at your-app.tld/vendor/laravel-pdf-tinker/playground
.
Do you have an unlikely collision with your routes? No worries!
You may publish the configuration file (php artisan vendor:publish
) and edit the route_prefix
key in config/laravel-pdf-tinker.php
to use a different prefix of your liking.
Driver options
If you published the configuration file you can also update the default_driver_options.<your-driver-alias>
key to set the default options that will be set in the interface (under Configuration > Options).
This will just be used when you enter the playground, you can always update the configuration inside the playground.
Any changes will not be persisted once you leave the page, so if you tinker a lot you might want to override the default options.
Drivers
Currently there are two drivers available.
DomPDF
DomPdf is the easiest driver to get started. Everything should already be in place after following the installation instructions.
Happy tinkering!
Wkhtmltopdf
The wkhtmltopdf driver needs the wkhtmltopdf
executable to be available in your PATH.
This means that if you run wkhtmltopdf --version
in a terminal it should output something like the following:
$ wkhtmltopdf --version wkhtmltopdf 0.12.5 (with patched qt)
If you're using mac&homebrew you can run brew cask install wkhtmltopdf
.
On any other system download the binaries for your system from the wkhtmltopdf website.
Creating your own drivers
It's possible to create a driver of the HTML2PDF generation library of your choice. Simply create your driver and register it with the PdfTinkerManager
.
- First things first, this is the time to create your driver. Your driver should extend
\Traincase\HtmlToPdfTinker\Drivers\Driver
. You can take an example fromTraincase\LaravelPdfTinker\DompdfDriver
. - Register it with the
PdfTinkerManager
. Add the following lines to one of your registered service providers in theboot
method.public function boot() { if ($this->app->isLocal()) { $this->app->resolving(\Traincase\HtmlToPdfTinker\PdfTinkerManager::class, function($manager) { $manager->extend('test-driver', function() { // Need to fetch some things from the container? Sure. $dependency = $this->app->make(\SomeFancyClass::class); return new \App\Drivers\YourFancyDriver($dependency); }); }); } }
- Your driver will automatically show up in the interface in the drivers dropdown, you're free to tinker!
Ready, set...
If you followed all the installation instructions go ahead and tinker away! Open up your browser and navigate to your-app.tld/vendor/laravel-pdf-tinker/playground
.