npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@pmee/schemas

v0.0.1

Published

TypeScript base PDF generator and React base UI. Open source, developed by the community, and completely free to use under the MIT license!

Downloads

172

Readme

PDFME

Features

| Fast PDF Generator | Easy PDF template design | Simple JSON template | | -------------------------------------------------------------------------------------------- | ----------------------------------------------------- | -------------------------------------------------------------- | | Works on node and browser. Use templates to generate PDF, Complex operations are not needed. | Anyone can easily create templates with the designer. | Templates are JSON data that is easy to understand and handle. |


Introduction

pdfme was created to simplify the design and generation process of a PDF. It is especially useful for the following use cases:

  • Need to create a designed PDF with short code.
  • Need to integrate PDF editor features into an application.
  • Need to create a large number of PDFs without compromising performance

As an example, the author's service https://labelmake.jp/ can create more than 100 varieties of PDFs and generates more than 100,000 PDF files per month. Notably, the monthly server cost, utilizing Cloud Functions For Firebase, remains below $10.

Installation

The operating requirements should be the node environment >=16.
There are two packages in pdfme, generator and UI.

The package for generating PDF can be installed with the following command.

npm i @pdfme/generator @pdfme/common

The packages for using PDF designer, forms and viewers can be installed with the following commands.

npm i @pdfme/ui @pdfme/common

*You must install @pdfme/common regardless of which package you use.

On NPM stable releases are published to the latest tag, and pre-releases are published to the next tag. On the dev tag you can find releases for every commit to the main branch.

The following type, function and classes are available in pdfme.

@pdfme/common

@pdfme/generator

@pdfme/ui

If your environment uses webpack, import the necessary items as shown below.

import type { Template } from '@pdfme/common';
import { generate } from '@pdfme/generator';
import type { Template } from '@pdfme/common';
import { Designer, Form, Viewer } from '@pdfme/ui';

All objects use Template, which will be briefly explained in the next section.

Template

The core of pdfme library are Templates.
Template Type can be imported by both @pdfme/generator or @pdfme/ui. Templates are used everywhere.

A template can be divided into two parts: a fixed part and a variable part.
We call them basePdf and schema. The following image is a good illustration of a template.

  • basePdf: PDF data for the fixed part of the PDF to be generated.
  • schemas: Definition data for the variable part of the PDF to be generated.

basePdf can be given a string(base64), ArrayBuffer, or Uint8Array.
A blank A4 PDF can be imported with BLANK_PDF. You can use it to check how it works.

Schemas can only utilize text by default, but you can load images and various barcodes like QR codes as plugins from the @pdfme/schemas package.
Additionally, you can create your own schemas, allowing you to render types other than the ones mentioned above. Check detail about Custom Schemas from here.

Let's take a look at some specific data.
(If you are using TypeScript, you can import the Template type.)

Minimal Template

import { Template, BLANK_PDF } from '@pdfme/common';

const template: Template = {
  basePdf: BLANK_PDF,
  schemas: [
    [
      {
        name: 'a',
        type: 'text',
        position: { x: 0, y: 0 },
        width: 10,
        height: 10,
      },
      {
        name: 'a',
        type: 'text',
        position: { x: 10, y: 10 },
        width: 10,
        height: 10,
      },
      {
        name: 'c',
        type: 'text',
        position: { x: 20, y: 20 },
        width: 10,
        height: 10,
      },
    ],
  ],
};

You can create a template from Template Design page. Or, if you want to integrate the template creation feature into your application, check out the Designer section.

Generator

The PDF generator function, generate, takes 2 arguments of template and inputs for generate a PDF. It works both in Node.js and in the browser.

The code to generate a PDF file using the template created above is shown below.

import type { Template } from '@pdfme/common';
import { generate } from '@pdfme/generator';

const template: Template = {
  // skip... Check the Template section.
};
const inputs = [{ a: 'a1', b: 'b1', c: 'c1' }];

generate({ template, inputs }).then((pdf) => {
  console.log(pdf);

  // Browser
  // const blob = new Blob([pdf.buffer], { type: 'application/pdf' });
  // window.open(URL.createObjectURL(blob));

  // Node.js
  // fs.writeFileSync(path.join(__dirname, `test.pdf`), pdf);
});

You can create a PDF file like the below.

Also, each element in the inputs array corresponds to a page in the PDF, you can create a multi-page PDF file by providing multiple elements of inputs.

UI

The UI is composed of the Designer, Form, and Viewer classes.

Designer

The Designer allows you to edit the Template schemas, making it easy for anyone to create Template json objects.

You can design your own template from Template Design page, or you can integrate the designer into your application.

Let's integrate the designer using the template created above as the default template.

import type { Template } from '@pdfme/common';
import { Designer } from '@pdfme/ui';

const domContainer = document.getElementById('container');
const template: Template = {
  // skip... Check the Template section.
};

const designer = new Designer({ domContainer, template });

The Designer class is instantiated as shown above, and the template designer is displayed in the domContainer.
You can edit the template as shown below. The operation is like Google Slides, etc., so you can use common keyboard shortcuts.

The designer instance can be manipulated with the following methods.

  • saveTemplate
  • updateTemplate
  • getTemplate
  • onChangeTemplate
  • onSaveTemplate
  • destroy

Form

You can use templates to create forms and PDF viewers.

The Form creates a UI for the user to enter schemas based on the template.

import type { Template } from '@pdfme/common';
import { Form } from '@pdfme/ui';

const domContainer = document.getElementById('container');
const template: Template = {
  // skip...
};
// This is initial data.
const inputs = [{ a: 'a1', b: 'b1', c: 'c1' }];

const form = new Form({ domContainer, template, inputs });

The form instance has a method getInputs to get the user's input.

You can generate a PDF file based on the user's input by passing the data you get from getInputs as inputs to generate, as shown in the code below.

generate({ template, inputs: form.getInputs() }).then((pdf) => {
  const blob = new Blob([pdf.buffer], { type: 'application/pdf' });
  window.open(URL.createObjectURL(blob));
});

Viewer

Viewing a PDF file in a mobile browser is a pain, because it doesn't display well in an iframe.

The Viewer is a byproduct of the Form development process, but it allows you to show your users a preview of the PDF file you will create.

Using the Viewer is basically the same as using the Form, except that user cannot edit it.

import type { Template } from '@pdfme/common';
import { Viewer } from '@pdfme/ui';

const domContainer = document.getElementById('container');
const template: Template = {
  // skip...
};
const inputs = [{ a: 'a1', b: 'b1', c: 'c1' }];

const viewer = new Viewer({ domContainer, template, inputs });

Using additional schemas and custom plugins

The examples so far use only the text schema type. There are many others built-in within the @pdfme/schemas package, and you can use your own:

Here's an example using additional schemas from built-in and custom plugins:

import { Template, BLANK_PDF } from '@pdfme/common';
import { text, barcodes, image } from '@pdfme/schemas';
import myPlugin from './custom-plugins';

const template: Template = {
  basePdf: BLANK_PDF,
  schemas: [
    [
      {
        name: 'example_text',
        type: 'text',
        position: { x: 0, y: 0 },
        width: 40,
        height: 10,
      },
      {
        name: 'example_image',
        type: 'image',
        position: { x: 200, y: 200 },
        width: 60,
        height: 40,
      },
      {
        name: 'example_qr_code',
        type: 'qrcode',
        position: { x: 100, y: 100 },
        width: 50,
        height: 50,
      },
    ],
  ],
};

const plugins = {
  Text: multiVariableText,
  'QR Code': barcodes.qrcode,
  Image: image,
  MyPlugin: myPlugin
}

const inputs = [{ 
  example_text: 'a1', 
  example_image: '....', 
  example_qr_code: 'https://pdfme.com/' 
}];

generate({ template, inputs, plugins }).then((pdf) => {
    console.log(pdf);
});

Examples using pdfme

If you are looking for code examples using pdfme to get started, please check out the pdfme-playground repository or look at the examples in the websit/src/pages/ folder of this repository. Settings these up is covered in the DEVELOPMENT.md file.

Special Thanks

I definitely could not have created pdfme without these libraries. I am grateful to the developers of these libraries.

If you want to contribute to pdfme, please check the Development Guide page.
We look forward to your contribution!

Cloud Service Option

While pdfme is a powerful open-source library, we understand that some users might prefer a managed solution. For those looking for a ready-to-use, scalable PDF generation service without the need for setup and maintenance, we offer pdfme Cloud.

Try pdfme Cloud - Hassle-free PDF Generation

pdfme Cloud provides all the features of the open-source library, plus:

  • PDF generation at scale without infrastructure management
  • Hosted WYSIWYG template designer
  • Simple API integration
  • Automatic updates and maintenance

*pdfme is and will always remain open-source. The cloud service is an optional offering for those who prefer a managed solution.