azakur4 / lum-pdf
compatibility fork of k98kurz/pdf-lumen (dompdf wrapper) for Laravel Lumen
Requires
- php: >=5.3.0
This package is not auto-updated.
Last update: 2024-12-25 21:20:23 UTC
README
Compatibility conversion of k98kurz/pdf-lumen for Laravel Lumen 5.* Simple Dompdf wrapper package (uses Dompdf stable version 0.5)
By: Azakur4/lum-pdf
Installation
Add azakur4/lum-pdf
to composer.json
.
"azakur4/lum-pdf": "dev-master"
Run composer update
to pull down the latest version of Pdf.
Now open up bootstrap/app.php
and add the service provider.
$app->register('azakur4\Pdf\PdfServiceProvider');
Now add the alias.
class_alias('azakur4\Pdf\PdfFacade', 'PDF');
Configuration
Copy the default configuration file from the config folder of this project to your application root config folder dompdf.php
Now open up bootstrap/app.php
and add this line:
$app->configure('dompdf');
Usage
Show a PDF
$app->get('/', function () { $html = '<html><body>' . '<p>Put your html here, or generate it with your favourite ' . 'templating system.</p>' . '</body></html>'; return PDF::load($html, 'A4', 'portrait')->show(); });
Download a PDF
$app->get('/', function () { $html = '<html><body>' . '<p>Put your html here, or generate it with your favourite ' . 'templating system.</p>' . '</body></html>'; return PDF::load($html, 'A4', 'portrait')->download('my_pdf'); });
Returns a PDF as a string
$app->get('/', function () { $html = '<html><body>' . '<p>Put your html here, or generate it with your favourite ' . 'templating system.</p>' . '</body></html>'; $pdf = PDF::load($html, 'A4', 'portrait')->output(); });
Multiple PDFs
for ($i=1;$i<=2;$i++) { $pdf = new \k98kurz\Pdf\Pdf(); $content = $pdf->load(View::make('pdf.image'))->output(); File::put(public_path('test'.$i.'.pdf'), $content); } PDF::clear();
Examples
Save the PDF to a file in a specific folder, and then mail it as attachement. By @w0rldart
define('BUDGETS_DIR', public_path('uploads/budgets')); // I define this in a constants.php file if (!is_dir(BUDGETS_DIR)){ mkdir(BUDGETS_DIR, 0755, true); } $outputName = str_random(10); // str_random is a [Laravel helper](http://laravel.com/docs/helpers#strings) $pdfPath = BUDGETS_DIR.'/'.$outputName.'.pdf'; File::put($pdfPath, PDF::load($view, 'A4', 'portrait')->output()); Mail::send('emails.pdf', $data, function($message) use ($pdfPath){ $message->from('us@example.com', 'Laravel'); $message->to('you@example.com'); $message->attach($pdfPath); });