Gathering detailed insights and metrics for @pdfme-tables/common
Gathering detailed insights and metrics for @pdfme-tables/common
Gathering detailed insights and metrics for @pdfme-tables/common
Gathering detailed insights and metrics for @pdfme-tables/common
A TypeScript based PDF generator library, made with React.
npm install @pdfme-tables/common
Typescript
Module System
Node Version
NPM Version
44.2
Supply Chain
83.1
Quality
77.1
Maintenance
100
Vulnerability
97.6
License
TypeScript (98.65%)
JavaScript (0.93%)
CSS (0.22%)
Shell (0.17%)
HTML (0.04%)
Total Downloads
535
Last Day
2
Last Week
4
Last Month
11
Last Year
535
687 Commits
1 Branches
1 Contributors
Latest Version
0.0.5
Package Id
@pdfme-tables/common@0.0.5
Unpacked Size
972.93 kB
Size
355.81 kB
File Count
41
NPM Version
10.5.2
Node Version
20.13.1
Publised On
05 Jul 2024
Cumulative downloads
Total Downloads
Last day
100%
2
Compared to previous day
Last week
33.3%
4
Compared to previous week
Last month
10%
11
Compared to previous month
Last year
0%
535
Compared to previous year
3
2
TypeScript base PDF generator and React base UI. Open source, developed by the community, and completely free to use under the MIT license!
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. |
pdfme was created to simplify the design and generation process of a PDF. It is especially useful for the following use cases:
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.
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.
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.
1import type { Template } from '@pdfme-tables/common'; 2import { generate } from '@pdfme-tables/generator';
1import type { Template } from '@pdfme-tables/common'; 2import { Designer, Form, Viewer } from '@pdfme-tables/ui';
All objects use Template
, which will be briefly explained in the next section.
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 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.)
1import { Template, BLANK_PDF } from '@pdfme-tables/common'; 2 3const template: Template = { 4 basePdf: BLANK_PDF, 5 schemas: [ 6 { 7 a: { 8 type: 'text', 9 position: { x: 0, y: 0 }, 10 width: 10, 11 height: 10, 12 }, 13 b: { 14 type: 'text', 15 position: { x: 10, y: 10 }, 16 width: 10, 17 height: 10, 18 }, 19 c: { 20 type: 'text', 21 position: { x: 20, y: 20 }, 22 width: 10, 23 height: 10, 24 }, 25 }, 26 ], 27};
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.
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.
1import type { Template } from '@pdfme-tables/common'; 2import { generate } from '@pdfme-tables/generator'; 3 4const template: Template = { 5 // skip... Check the Template section. 6}; 7const inputs = [{ a: 'a1', b: 'b1', c: 'c1' }]; 8 9generate({ template, inputs }).then((pdf) => { 10 console.log(pdf); 11 12 // Browser 13 // const blob = new Blob([pdf.buffer], { type: 'application/pdf' }); 14 // window.open(URL.createObjectURL(blob)); 15 16 // Node.js 17 // fs.writeFileSync(path.join(__dirname, `test.pdf`), pdf); 18});
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.
The UI is composed of the Designer, Form, and Viewer classes.
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.
1import type { Template } from '@pdfme-tables/common'; 2import { Designer } from '@pdfme-tables/ui'; 3 4const domContainer = document.getElementById('container'); 5const template: Template = { 6 // skip... Check the Template section. 7}; 8 9const 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
getPageCursor
onChangeTemplate
onSaveTemplate
destroy
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.
1import type { Template } from '@pdfme-tables/common'; 2import { Form } from '@pdfme-tables/ui'; 3 4const domContainer = document.getElementById('container'); 5const template: Template = { 6 // skip... 7}; 8// This is initial data. 9const inputs = [{ a: 'a1', b: 'b1', c: 'c1' }]; 10 11const 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.
1generate({ template, inputs: form.getInputs() }).then((pdf) => {
2 const blob = new Blob([pdf.buffer], { type: 'application/pdf' });
3 window.open(URL.createObjectURL(blob));
4});
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.
1import type { Template } from '@pdfme-tables/common'; 2import { Viewer } from '@pdfme-tables/ui'; 3 4const domContainer = document.getElementById('container'); 5const template: Template = { 6 // skip... 7}; 8const inputs = [{ a: 'a1', b: 'b1', c: 'c1' }]; 9 10const viewer = new Viewer({ domContainer, template, inputs });
pdf-lib: Used in PDF generation.
fontkit: Used in font rendering.
PDF.js: Used in PDF viewing.
React: Used in building the UI.
form-render: Used in building the UI.
antd: Used in building the UI.
react-moveable, react-selecto, @scena/react-guides: Used in Designer UI.
dnd-kit: Used in Designer UI.
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!
No vulnerabilities found.
No security vulnerabilities found.