27_Images_Html_Pdf.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\IOFactory;
  3. use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
  4. use PhpOffice\PhpSpreadsheet\Shared\File;
  5. use PhpOffice\PhpSpreadsheet\Worksheet\PageSetup;
  6. use PhpOffice\PhpSpreadsheet\Writer\Pdf\Mpdf;
  7. use PhpOffice\PhpSpreadsheet\Writer\Xlsx as XlsxWriter;
  8. require __DIR__ . '/../Header.php';
  9. // Read from Xls (.xls) template
  10. $helper->log('Load Xlsx template file');
  11. $reader = IOFactory::createReader('Xls');
  12. $initialSpreadsheet = $reader->load(__DIR__ . '/../templates/27template.xls');
  13. $xlsxFile = File::temporaryFilename();
  14. $writer = new XlsxWriter($initialSpreadsheet);
  15. $helper->log('Save as Xlsx');
  16. $writer->save($xlsxFile);
  17. $initialSpreadsheet->disconnectWorksheets();
  18. $reader2 = new XlsxReader();
  19. $helper->log('Load Xlsx');
  20. $spreadsheet = $reader2->load($xlsxFile);
  21. $helper->log('Hide grid lines');
  22. $spreadsheet->getActiveSheet()->setShowGridLines(false);
  23. $helper->log('Set orientation to landscape');
  24. $spreadsheet->getActiveSheet()->getPageSetup()->setOrientation(PageSetup::ORIENTATION_LANDSCAPE);
  25. $className = Mpdf::class;
  26. $helper->log("Write to PDF format using {$className}, and to Html");
  27. IOFactory::registerWriter('Pdf', $className);
  28. // Save
  29. $helper->write($spreadsheet, __FILE__, ['Pdf', 'Html']);
  30. unlink($xlsxFile);
  31. $spreadsheet->disconnectWorksheets();