Edición de «Exportar a PDF con cabecera y pie de pagina»

Saltar a: navegación, buscar

Advertencia: No has iniciado sesión. Tu dirección IP será visible públicamente si haces cualquier edición. Si inicias sesión o creas una cuenta, tus ediciones se atribuirán a tu nombre de usuario, junto con otros beneficios.

La edición puede deshacerse. Antes de deshacer la edición, comprueba la siguiente comparación para verificar que realmente es lo que quieres hacer, y entonces guarda los cambios para así deshacer la edición.
Revisión actual Tu texto
Línea 2: Línea 2:
 
Quiero complementar  agregando un encabezado y un pie de página que se repetirá cada vez.<br>
 
Quiero complementar  agregando un encabezado y un pie de página que se repetirá cada vez.<br>
 
Sin más preámbulo comencemos.<br>
 
Sin más preámbulo comencemos.<br>
Lo primero que haremos es instalar la librería MPDF a través de composer.<br>
+
Lo primero que haremos es cargar la librería MPDF a través de composer.<br>
  
 
<source lang="php">
 
<source lang="php">
Línea 16: Línea 16:
  
 
     public function export() {
 
     public function export() {
        //No mostramos template, como tampoco vista.
+
//No mostramos template, como tampoco vista.
 
         View::select(null, null);
 
         View::select(null, null);
        //llamamos al metodo estatico export de nuestro modelo Pdfreports pasando un titulo y un mensaje
+
//llamamos al metodo estatico export de nuestro modelo Pdfreports pasando un titulo y un mensaje
         PdfReports::export('Hola Kumbieros!');
+
         Pdfreports::export('Hola Kumbieros!');
 
     }
 
     }
  
Línea 25: Línea 25:
 
</source>
 
</source>
  
== Las Vistas ==
+
== La Vista ==
  
Ahora crearemos nuestras vistas parciales(partials), que tendrán la estructura de nuestro PDF, creamos el archivo en '''default/app/views/_shared/partials/reports/test/pdf.phtml'''
+
Ahora crearemos nuestra vista, que tendrá la estructura de nuestro PDF, creamos el archivo en '''default/app/views/_shared/partials/reports/test/pdf.phtml'''
 
<source lang="html5">
 
<source lang="html5">
 
<html lang="es">
 
<html lang="es">
Línea 48: Línea 48:
 
     </body>
 
     </body>
 
</html>
 
</html>
</source>
 
 
Del mismo modo creamos el partial para el encabezado y pie de pagina
 
'''default/app/views/_shared/partials/reports/test/header.phtml'''
 
<source lang="html5">
 
<table width="100%">
 
        <tr>
 
            <td width="50%" align="left"><img src="http://wiki.kumbiaphp.com/images/wikibanner.png"></td>
 
            <td width="50%" align="right">Tutorial Encabezados y pie de Pagína</td>
 
        </tr>
 
</table>
 
</source>
 
 
'''default/app/views/_shared/partials/reports/test/footer.phtml'''
 
<source lang="html5">
 
    <div>KumbiaPHP es un framework para aplicaciones web libre escrito en PHP.</div>
 
 
</source>
 
</source>
  
 
== Modelo ==
 
== Modelo ==
  
Ahora crearemos nuestro modelo pdf_reports.php en '''default/app/models.'''<br>
+
Ahora crearemos nuestro modelo pdfreports.php en '''default/app/models.'''<br>
 +
Hacemos referencia a nuestro autoload.php de la siguiente forma en nuestro modelo
  
 
<source lang="php">
 
<source lang="php">
 +
 +
require_once ROOT_PATH . 'vendor/autoload.php';
  
 
use Mpdf\Mpdf;
 
use Mpdf\Mpdf;
  
class PdfReports {
+
class Pdfreports {
  
     public static function getHeaderHtml() {
+
     private static $header_html = '
         //contenido del header alojada en el partials
+
         <table width="100%">
         ob_start();
+
         <tr>
        View::partial('reports/test/header');
+
            <td width="50%" align="left"><img src="http://wiki.kumbiaphp.com/images/wikibanner.png"></td>
        // Obtiene el html del búfer actual y elimina el búfer de salida actual
+
            <td width="50%" align="right">Tutorial Encabezados y pie de Pagína</td>
        return ob_get_clean();
+
         </tr>
    }
+
</table><hr>
 
+
    ';
    public static function getFooterHtml() {
+
     private static $footer_html = "KumbiaPHP es un framework para aplicaciones web libre escrito en PHP.";
        //contenido del footer alojada en el partials
+
         ob_start();
+
        View::partial('reports/test/footer');
+
        // Obtiene el html del búfer actual y elimina el búfer de salida actual
+
        return ob_get_clean();
+
     }
+
  
 
     public static function export($titulo) {
 
     public static function export($titulo) {
Línea 100: Línea 81:
 
         $mpdf->setAutoTopMargin = 'stretch';
 
         $mpdf->setAutoTopMargin = 'stretch';
 
         //establezco el HTML al header
 
         //establezco el HTML al header
         $mpdf->SetHTMLHeader(self::getHeaderHtml());
+
         $mpdf->SetHTMLHeader(self::$header_html);
  
 
         //contenido de la vista alojada en el partials
 
         //contenido de la vista alojada en el partials
Línea 110: Línea 91:
 
         //agrego el footer de pagina y esta
 
         //agrego el footer de pagina y esta
 
         $mpdf->setAutoBottomMargin = 'stretch';
 
         $mpdf->setAutoBottomMargin = 'stretch';
         $mpdf->SetHTMLFooter(self::getFooterHtml());
+
         $mpdf->SetHTMLFooter(self::$footer_html);
  
 
         // Agrego el contenido del Partials al HTML
 
         // Agrego el contenido del Partials al HTML
Línea 121: Línea 102:
 
}
 
}
 
</source>
 
</source>
 +
  
 
== Resultado ==
 
== Resultado ==
Línea 126: Línea 108:
 
Ahora abrimos nuestro navegador  ingresando a nuestra url '''http://localhost/tuweb/test/export'''
 
Ahora abrimos nuestro navegador  ingresando a nuestra url '''http://localhost/tuweb/test/export'''
 
Y se descargara nuestro PDF, el cual repite su encabezado y pie de página por cada hoja.
 
Y se descargara nuestro PDF, el cual repite su encabezado y pie de página por cada hoja.
[[Archivo:Exportar-pdf1.jpg]]
 
<br>
 
[[Archivo:Exportar-pdf2.jpg]]
 
 
--[[Usuario:Ekogro|Ekogro]]  19:24 14 ago 2018 (UTC)
 
[[Categoría:Tutoriales KumbiaPHP]]
 

Por favor observa que todas las contribuciones a KumbiaPHP Framework Wiki se consideran hechas públicas bajo la Attribution-Share Alike 3.0 Unported (véase KumbiaPHP Framework Wiki:Derechos de autor para más detalles). Si no deseas la modificación y distribución libre de tu obra, entonces no la pongas aquí.
También nos aseguras que tú escribiste esto y te pertenecen de los derechos de autor, o lo copiaste desde el dominio público u otra fuente libre. ¡No uses escritos con copyright sin permiso!

Cancelar | Ayuda de edición (se abre en una ventana nueva)