Как структурировать код, связанный с PDF, чтобы его не было в файле маршрутов?
Я использую Laravel Snappy PDF пакет https://github.com/barryvdh/laravel-snappy
Все работает отлично, однако файл маршрутов теперь содержит много информации, которую я хотел бы очистить из файла маршрутов и поместить в другое место.
Route::get('services/{service}/overview', function ($id) {
$service = \App\Service::where('id', '=', $id)->first();
$service->load('sbo_name', 'sbm_name', 'stm_name', 'get_lifecycle_status', 'items', 'environments', 'agreements', 'supported_services', 'required_services', 'serviceDependencies', 'readiness');
$data['service'] = $service->toArray();
$pdf = PDF::loadView('reports.services.overview', $data)
->setPaper('a4')
->setOrientation('portrait')
->setOption('footer-right', 'Page [page] of [toPage] ')
->setOption('footer-left', ' Printed: [date]')
->setOption('footer-font-size', 8)
->setOption('footer-font-name', 'Arial')
->setOption('margin-top', 10)
->setOption('margin-left', 5)
->setOption('margin-right', 5)
->setOption('lowquality', false)
->setOption('dpi', 96)
->setOption('image-quality', 100);
return $pdf->inline('Service Overview.pdf');
});
Каков наилучший способ структурировать это? Я не хочу повторять параметры PDF для каждого нового отчета.
1 ответ
Прежде всего, очистите ваши файлы маршрутов, переместив их в контроллер.
Route::get('services/{service}/overview', ExportServiceController@show);
// app/Http/Controllers/ExportServiceController.php
class ExportServiceController extends Controller
public function show($id) {
return (new App/ExportServicePdf)->execute($id);
}
Далее очистите свой контроллер, переместив логику в собственный класс, чтобы его можно было использовать в другом контроллере.
// for example app/ExportServicePdf.php
namespace App;
class ExportServicePdf
{
public function execute($id)
{
$service = \App\Service::where('id', '=', $id)->first();
$service->load('sbo_name', 'sbm_name', 'stm_name', 'get_lifecycle_status', 'items', 'environments', 'agreements', 'supported_services', 'required_services', 'serviceDependencies', 'readiness');
$data['service'] = $service->toArray();
$pdf = PDF::loadView('reports.services.overview', $data)
->setPaper('a4')
->setOrientation('portrait')
->setOption('footer-right', 'Page [page] of [toPage] ')
->setOption('footer-left', ' Printed: [date]')
->setOption('footer-font-size', 8)
->setOption('footer-font-name', 'Arial')
->setOption('margin-top', 10)
->setOption('margin-left', 5)
->setOption('margin-right', 5)
->setOption('lowquality', false)
->setOption('dpi', 96)
->setOption('image-quality', 100);
return $pdf->inline('Service Overview.pdf');
}
}
Быстрый рывок в библиотеку, есть публичный метод setOptions()
который принимает массив опций.
В вашем ExportServicePdf
класс, вы можете изменить его следующим образом:
class ExportServicePdf
{
private $options = [
'footer-font-size' => 8,
'footer-font-name' => 'Arial',
//...
];
// Then you can do
public function execute($id)
{
$pdf = PDF::loadView('reports.services.overview', $data)
->setPaper('a4')
->setOrientation('portrait')
->setOptions($this->options)
}
}