Как структурировать код, связанный с 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)
    }

}
Другие вопросы по тегам