Unbeantwortet
Erstellung und Versand einer Excel-Datei direkt aus einem JR-Prozess
Hey,
ja haben wir, siehe wie folgt. Kann man aus Dialogfunktionen und aus Regelausführungsfunktionen nutzen.
ACHTUNG: Der Aufruf von Utility:: funktioniert glaub ich ab 2024.1 nicht mehr. Muss man den Pfad klassisch zusammenbauen.
private function createExcel($preparedArray) {
require_once(Utility::getJobRouterPath() . '\library\vendor\phpoffice\phpspreadsheet\src\Bootstrap.php');
$spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
$spreadsheet->getActiveSheet()->fromArray($preparedArray);
foreach ($spreadsheet->getActiveSheet()->getColumnIterator() as $column) {
$spreadsheet->getActiveSheet()->getColumnDimension($column->getColumnIndex())->setAutoSize(true);
}
ob_start();
(new \PhpOffice\PhpSpreadsheet\Writer\Xlsx($spreadsheet))->save('php://output');
$tempFile = $this->getFullTempPath() . DIRECTORY_SEPARATOR . 'my_filename.xlsx';
file_put_contents($tempFile, ob_get_clean());
$this->attachFile($tempFile, 'MY_PT_FIELD');
unlink($tempFile);
}
345 Ansichten
0
Antworten
vor 8 Monaten
vor 8 Monaten
Super, vielen Dank!