Ir al contenido principal

Crear un PDF con Ionic 4 y PDF Make (Paso a Paso)

Uno de los requisitos que he tenido que crear en apps del mundo real es la necesidad de crear un contrato en PDF, el mismo que tenga una imagen, y se puede descargar al dispositivo.

PDF MAKE

Investigando he dado con una librería llamada PDF Make, aquí esta el sitio web si gustas darle un super vistazo al sin número de opciones que tiene. http://pdfmake.org/#/, hasta tiene una parte donde tu mismo puedes experimentar http://pdfmake.org/playground.html algunos cambios, pero nosotros lo tenemos que implementar en ionic 5. Así que veamos como.

Ionic 5 y Generación de PDF

Creamos una nueva aplicación en ionic con el comando:
ionic start crearPdf blank
Necesitamos dos directivas instalarla en nuestro proyecto, con los siguientes comandos:
ionic cordova plugin add cordova-plugin-file
npm install @ionic-native/file

En el modulo general, en app.module.ts tenemos que llamar al modulo file que nos ayudará una vez creado el PDF, generar el archivo para descarga. El código del app.module.ts quedaría así:

import { File } from '@ionic-native/file/ngx';
Y en los providers añadirlo, quedando así:
providers: [
    StatusBar,
    File,
    SplashScreen,
    { provide: RouteReuseStrategy, useClass: IonicRouteStrategy }
  ],
En el home.page.html o en la página donde quieras generar el PDF, deberás incluir un botón o un método que llame ta función, para este caso crearemos un botón que diga Generar PDF. Y quedaría de la siguiente forma:
<ion-content>
  <div id="wrapper">
    <ion-button color="primary" (click)='crearPdf()' >Generar PDF</ion-button>
  </div>
</ion-content>
En el archivo .ts del Home crearemos la función crearPDF, quedando así el archivo home.page.ts:

makePdf(){
    pdfmake.vfs = pdfFonts.pdfMake.vfs;
    var docDefinition = {
      content: [
      {
        columns: [
        {
          image: 'data:image/png;base64, (aqui tu imagen en base 64)
},
        [
          { text: 'CLARO', style: 'header' },
          { text: 'Contrato de Contratacion de Servicios', style: 'sub_header' },
          { text: 'WEBSITE: https://claro.com.ec/', style: 'url' },
        ]
      ]
      }
      ],
      styles: {
        header: {
          bold: true,
          fontSize: 20,
          alignment: 'right'
        },
      sub_header: {
        fontSize: 18,
        alignment: 'right'
      },
      url: {
      fontSize: 16,
      alignment: 'right'
      }
      },
      pageSize: 'A4',
      pageOrientation: 'portrait'
      };
      /* pdfmake.createPdf(docDefinition).open(); */
      pdfmake.createPdf(docDefinition).download('archivo');
  }

Finalmente compilamos todo el proyecto con ionic serve y funcionaría así.


Finalmente se descarga el PDF y listo terminamos por el día de hoy.


Comentarios

Entradas populares de este blog

Cómo crear un diseño responsive en Ionic 4

Tutorial Principiante. Hola que tal el día de hoy hablamos sobre crear diseños adapatables a cada pantalla donde se ejecuta la aplicación, con el uso de la etiqueta ION-GRID dentro del código de ionic, el sitio de la documentación oficial nos dice lo siguiente: La cuadrícula es un potente sistema flexbox móvil primero para crear diseños personalizados. Se compone de tres unidades: una cuadrícula, fila (s) y columna (s). Las columnas se expandirán para llenar la fila y cambiarán de tamaño para adaptarse a columnas adicionales. Se basa en un diseño de 12 columnas con diferentes puntos de interrupción en función del tamaño de la pantalla. El número de columnas se puede personalizar con CSS. Básicamente para los que sabemos bootstrap es más de lo mismo un sistema en el cual puedes distribuir tus elementos en la pantalla con toda la ventaja de que es adaptable al dispositivo en donde se esta ejecutando. Su uso: < ion-grid > < ion-row > < ion-col size ...

Ejecutar tu app de Ionic 4 en un emulador Android

Hola que tal amigos, el dia de hoy me gustaría poder compartirles cómo ejecutar las apps desarrolladas en Ionic 4 y ejecutarlas en la misma PC per en un dispositivo android. Instalando Android Studio Para poder realizar esta operación, necesitamos instalar Android Studio  tiene un peso de 750 megas, así que relájate mientras se descarga. Una vez que se descarga instalalo, de repente vas a necesitar JDK Java Development Kit , te dejo el link para que lo puedas descargar e instalarlo antes de Android Studio. Creando un AVD Una vez instalado Android Studio, nos vamos a crear un dispositivo virtual donde se ejecutará nuestra app. 1.- Vamos al menú principal, y damos clic en la opción Herramientas (Tools) después clic en -> AVD Manager -> Clic en crear Nuevo Dispositivo Virtual. 2.- Seleccionamos un dispositivo de la lista por ejemplo Nexus. y Listo!!! ya tenemos nuestro dispositivo virtual para probar nuestra aplicación. 3.- Ejecutamos el disp...

Convertir una imagen PNG/JPG a base64 en Ionic 4

Las imágenes se trabajan en base64 para poderlas enviar a traves de un objeto JSON a las API's o micro servicios, por eso es importante que nuestra app internamente convierta un jpg,png desde los assets a una base64. En este episodio hablaremos de como seleccionar una imagen desde la galeria y convertirla en un string valido en base64. Primero crear el proyecto mediante el comando: ionic start imagenBase64 blank Entramos al directorio de la aplicación y vamos a instalar las dependencias que vamos a ir necesitando para este proyecto, las voy a ir listando a continuación cada una: ionic cordova plugin add cordova-plugin-camera npm install @ionic-native/camera ionic cordova plugin add cordova-plugin-file npm install @ionic-native/file ionic cordova plugin add cordova-plugin-crop npm install @ionic-native/crop Una vez instaladas todas estas dependencias ahora si vamos abrir el proyecto en nuestro editor de código favoritos, el mio es Visual Studio Code. Abrimos ...