fetchArray('SELECT * FROM zz_prints WHERE enabled = 1 ORDER BY `order`'); $prints = []; // Inizializzazione dei riferimenti $modules = Modules::getModules(); foreach ($modules as $module) { self::$modules[$module['id']] = []; } foreach ($results as $result) { $result['full_directory'] = DOCROOT.'/templates/'.$result['directory']; $prints[$result['id']] = $result; $prints[$result['name']] = $result['id']; self::$modules[$result['id_module']][] = $result['id']; } self::$prints = $prints; } return self::$prints; } /** * Restituisce le informazioni relative a una singolo stampa specificata. * * @param string|int $print * * @return array */ public static function get($print) { if (!is_numeric($print) && !empty(self::getPrints()[$print])) { $print = self::getPrints()[$print]; } return self::getPrints()[$print]; } /** * Restituisce le informazioni relative alle stampe di un singolo modulo specificato. * * @param string|int $module * * @return array */ public static function getModulePrints($module) { $module_id = Modules::get($module)['id']; self::getPrints(); $result = []; foreach ((array) self::$modules[$module_id] as $value) { $print = self::get($value); if (!empty($print['is_record'])) { $result[] = $print; } } return $result; } /** * Restituisce le informazioni relative alle stampe di un singolo modulo specificato. * * @param string|int $module * * @return array */ public static function getModulePredefinedPrint($module) { $prints = self::getModulePrints($module); $predefined = array_search(1, array_column($prints, 'predefined')); if ($predefined !== false) { return $prints[$predefined]; } elseif (!empty($prints)) { return $prints[0]; } return false; } /** * Genera la stampa in PDF richiesta. * * @param string|int $print * @param int $id_record * @param string $directory */ public static function render($print, $id_record, $directory = null) { //ob_end_clean(); // Compatibilità con versioni vecchie delle stampe $infos = self::get($print); Permissions::addModule($infos['id_module']); $has_access = true; if (!empty($infos['is_record'])) { $module = Modules::get($infos['id_module']); Util\Query::setSegments(false); $query = Util\Query::getQuery($module, [ 'id' => $id_record, ]); Util\Query::setSegments(true); $has_access = database()->fetchNum($query) !== 0; } if (empty($infos) || empty($infos['enabled']) || !Permissions::check([], false) || !$has_access) { return false; } // Individuazione della configurazione if (!empty($directory) && !directory($directory)) { $error = tr('Non hai i permessi per creare directory e files in _DIRECTORY_', [ '_DIRECTORY_' => $directory, ]); flash()->error($error); echo '

'.$error.'

'; exit(); } if (self::isOldStandard($print)) { return self::oldLoader($infos['id'], $id_record, $directory); } else { return self::loader($infos['id'], $id_record, $directory); } } /** * Individua il link per la stampa. * * @param string|int $print * @param int $id_record * @param string $get * * @return string */ public static function getHref($print, $id_record, $get = '') { $infos = self::get($print); if (empty($infos)) { return false; } $link = ROOTDIR.'/pdfgen.php?'; if (self::isOldStandard($infos['id'])) { $link .= 'ptype='.$infos['directory']; $link .= !empty($infos['previous']) && !empty($id_record) ? '&'.$infos['previous'].'='.$id_record : ''; } else { $link .= 'id_print='.$infos['id']; $link .= !empty($id_record) ? '&id_record='.$id_record : ''; } $link .= !empty($get) ? '&'.$get : ''; return $link; } /** * Restituisce il codice semplificato per il link alla stampa. * * @deprecated 2.4.1 * * @param string|int $print * @param int $id_record * @param string $btn * @param string $title * @param string $icon * @param string $get * * @return string */ public static function getLink($print, $id_record, $btn = null, $title = null, $icon = null, $get = '') { return '{( "name": "button", "type": "print", "id": "'.$print.'", "id_record": "'.$id_record.'", "label": "'.$title.'", "icon": "'.$icon.'", "parameters": "'.$get.'", "class": "'.$btn.'" )}'; } /** * Restituisce il link per la visualizzazione della stampa. * * @param string|int $print * @param int $id_record * @param string $directory * * @return string */ public static function getPreviewLink($print, $id_record, $directory) { $info = self::render($print, $id_record, $directory); return self::getPDFLink($info['path']); } /** * Restituisce il link per la visualizzazione del PDF. * * @param string $path * * @return string */ public static function getPDFLink($path) { return ROOTDIR.'/assets/dist/pdfjs/web/viewer.html?file=../../../../'.ltrim(str_replace(DOCROOT, '', $path), '/'); } /** * Individua il percorso per il file. * * @param string|int $template * @param string $file * * @return string|null */ public static function filepath($template, $file) { $template = self::get($template); $directory = 'templates/'.$template['directory'].'|custom|'; return App::filepath($directory, $file); } /** * Restituisce un array associativo dalla codifica JSON delle opzioni di stampa. * * @param string $string * * @return array */ protected static function readOptions($string) { // Fix per contenuti con newline integrate $string = str_replace(["\n", "\r"], ['\\n', '\\r'], $string); $result = (array) json_decode($string, true); return $result; } /** * Controlla se la stampa segue lo standard HTML2PDF. * * @param string|int $print * * @return bool */ protected static function isOldStandard($print) { $infos = self::get($print); return file_exists($infos['full_directory'].'/pdfgen.'.$infos['directory'].'.php') || file_exists($infos['full_directory'].'/custom/pdfgen.'.$infos['directory'].'.php'); } /** * Controlla se la stampa segue lo standard MPDF. * * @param string|int $print * * @return bool */ protected static function isNewStandard($print) { return !self::isOldStandard($print); } /** * Crea la stampa secondo il formato deprecato HTML2PDF. * * @param string|int $id_print * @param int $id_record * @param string $directory * @param string $format */ protected static function oldLoader($id_print, $id_record, $directory = null, $format = 'A4') { $infos = self::get($id_print); $options = self::readOptions($infos['options']); $docroot = DOCROOT; $dbo = $database = database(); $user = Auth::user(); $_GET[$infos['previous']] = $id_record; ${$infos['previous']} = $id_record; $ptype = $infos['directory']; $orientation = 'P'; $body_table_params = "style='width:210mm;'"; $table = 'margin-left:1.7mm'; $font_size = '10pt'; // Decido se usare la stampa personalizzata (se esiste) oppure quella standard if (file_exists($infos['full_directory'].'/custom/pdfgen.'.$infos['directory'].'.php')) { include $infos['full_directory'].'/custom/pdfgen.'.$infos['directory'].'.php'; } else { include $infos['full_directory'].'/pdfgen.'.$infos['directory'].'.php'; } // Sostituzione di variabili generiche $report = str_replace('$body$', $body, $report); $report = str_replace('$footer$', $footer, $report); $report = str_replace('$font_size$', $font_size, $report); $report = str_replace('$body_table_params$', $body_table_params, $report); $report = str_replace('$table$', $table, $report); // Footer di default if (!str_contains($report, '')) { $report .= '$default_footer$'; } // Operazioni di sostituzione include DOCROOT.'/templates/replace.php'; $mode = !empty($directory) ? 'F' : 'I'; $file = self::getFile($infos, $id_record, $directory, $replaces); $title = $file['name']; $path = $file['path']; $html2pdf = new Spipu\Html2Pdf\Html2Pdf($orientation, $format, 'it', true, 'UTF-8'); $html2pdf->writeHTML($report); $html2pdf->pdf->setTitle($title); $html2pdf->output($path, $mode); return $file; } protected static function getFile($record, $id_record, $directory, $original_replaces) { $module = Modules::get($record['id_module']); $name = $record['filename'].'.pdf'; $name = $module->replacePlaceholders($id_record, $name); $replaces = []; foreach ($original_replaces as $key => $value) { $key = str_replace('$', '', $key); $replaces['{'.$key.'}'] = $value; } $name = replace($name, $replaces); $filename = sanitizeFilename($name); $file = rtrim($directory, '/').'/'.$filename; return [ 'name' => $name, 'path' => $file, ]; } /** * Crea la stampa secondo il formato modulare MPDF. * * @param string|int $id_print * @param int $id_record * @param string $directory */ protected static function loader($id_print, $id_record, $directory = null) { $infos = self::get($id_print); $options = self::readOptions($infos['options']); $dbo = $database = database(); $user = Auth::user(); // Generazione a singoli pezzi $single_pieces = self::filepath($id_print, 'piece.php'); // Impostazioni di default $default = include App::filepath('templates/base|custom|', 'settings.php'); // Impostazioni personalizzate della stampa $custom = include self::filepath($id_print, 'settings.php'); // Individuazione delle impostazioni finali $settings = array_merge($default, (array) $custom); // Individuazione delle variabili fondamentali per la sostituzione dei contenuti include self::filepath($id_print, 'init.php'); // Individuazione delle variabili per la sostituzione include DOCROOT.'/templates/info.php'; // Instanziamento dell'oggetto mPDF $mpdf = new \Mpdf\Mpdf([ 'mode' => 'utf-8', 'format' => $settings['format'], 'orientation' => strtoupper($settings['orientation']) == 'L' ? 'L' : 'P', 'font-size' => $settings['font-size'], 'margin_left' => $settings['margins']['left'], 'margin_right' => $settings['margins']['right'], 'margin_top' => $settings['margins']['top'] + $settings['header-height'], 'margin_bottom' => $settings['margins']['bottom'] + $settings['footer-height'], 'margin_header' => $settings['margins']['top'], 'margin_footer' => $settings['margins']['bottom'], // Abilitazione per lo standard PDF/A //'PDFA' => true, //'PDFAauto' => true, ]); // Inclusione dei fogli di stile CSS $styles = [ 'templates/base/bootstrap.css', 'templates/base/style.css', ]; foreach ($styles as $value) { $mpdf->WriteHTML(file_get_contents(DOCROOT.'/'.$value), 1); } // Impostazione del font-size $mpdf->WriteHTML('body {font-size: '.$settings['font-size'].'pt;}', 1); // Generazione totale if (empty($single_pieces)) { ob_start(); include self::filepath($id_print, 'body.php'); $report = ob_get_clean(); if (!empty($autofill)) { $result = $autofill->generate(); $report = str_replace('|autofill|', $result, $report); } } // Generazione dei contenuti dell'header ob_start(); include self::filepath($id_print, 'header.php'); $head = ob_get_clean(); // Generazione dei contenuti del footer ob_start(); include self::filepath($id_print, 'footer.php'); $foot = ob_get_clean(); // Header di default $head = !empty($head) ? $head : '$default_header$'; // Footer di default $foot = !empty($foot) ? $foot : '$default_footer$'; // Operazioni di sostituzione include DOCROOT.'/templates/replace.php'; // Impostazione di header e footer $mpdf->SetHTMLFooter($foot); $mpdf->SetHTMLHeader($head); // Generazione dei contenuti della stampa if (!empty($single_pieces)) { ob_start(); include self::filepath($id_print, 'top.php'); $top = ob_get_clean(); $top = str_replace(array_keys($replaces), array_values($replaces), $top); $mpdf->WriteHTML($top); foreach ($records as $record) { ob_start(); include self::filepath($id_print, 'piece.php'); $piece = ob_get_clean(); $mpdf->WriteHTML($piece); } ob_start(); include self::filepath($id_print, 'bottom.php'); $bottom = ob_get_clean(); $bottom = str_replace(array_keys($replaces), array_values($replaces), $bottom); $mpdf->WriteHTML($bottom); $report = ''; } // Operazioni di sostituzione include DOCROOT.'/templates/replace.php'; $mode = !empty($directory) ? 'F' : 'I'; $file = self::getFile($infos, $id_record, $directory, $replaces); $title = $file['name']; $path = $file['path']; // Impostazione del titolo del PDF $mpdf->SetTitle($title); // Aggiunta dei contenuti $mpdf->WriteHTML($report); // Creazione effettiva del PDF $mpdf->Output($path, $mode); return $file; } }