Free and open source tool chain for generating EN16931 conforming e-invoices (Factur-X/ZUGFeRD, UBL, CII, XRechnung) from popular spreadsheet formats or JSON.
This package contains the core library of @e-invoice-eu/core
. Both the
E-Invoice-EU command line tool
and the E-Invoice-EU web service
use it as their foundation.
The library can create e-invoices in the following formats:
E-Invoices can be created directly from data in the E-Invoice-EU internal
format
or via a mapping definition
from popular spreadsheet formats like .ods
, .xlsx
, .csv
, ...
The library is implemented in TypeScript and provides complete type definitions out of the box. No additional @types package is required. All data structures, including those for the internal invoice format and mapping definitions, are fully typed, ensuring comprehensive IntelliSense support.
The library is available as an ES module, CommonJS, and UMD, making it compatible with both browser environments and JavaScript runtimes like Node.js.
The general documentation of e-invoice-eu
is available at the
e-invoice-eu
GitHub page.
For reference, you can also consult the
API documentation.
npm install @e-invoice-eu/core
If you have the import
keyword:
import { InvoiceService, MappingService } from '@e-invoice-eu/core';
With require
:
const { InvoiceService, MappingService } = require('@e-invoice-eu/core');
In the browser:
<script src="https://cdn.jsdelivr.net/npm/@e-invoice-eu/core@latest/dist/e-invoice-eu.min.js"></script>
<script>
const invoiceService = new eInvoiceEU.InvoiceService(/* arguments */);
const mappingService = new eInvoiceEU.MappingService(/* arguments */);
// Your code goes here ...
</script>
For this optional step, you need both the spreadsheet file as a Buffer
and a
mapping definition as a
Mapping
object:
import { MappingService } from '@e-invoice-eu/core';
const mappingService = new MappingService(console);
const invoice = mappingService.transform(
spreadsheet, // a `Buffer`
'Factur-X-Extended', // see https://gflohr.github.io/e-invoice-eu/en/docs/basics/supported-formats/
mapping, // a `Mapping`
);
The returned invoice
object is an
Invoice
instance in the internal format. It is not yet an XML string or PDF buffer!
You can either provide the invoice data yourself as an
Invoice
instance or you can create it from spreadsheet data and a mapping definition
as shown in the previous section.
import { InvoiceService } from '@e-invoice-eu/core';
const invoiceService = new InvoiceService(console);
const renderedInvoice = await invoiceService.generate(invoiceData, options);
See this summary for the options
(optional options are marked with an
question mark ?
):
Name | Type | Description |
---|---|---|
format | string |
a supported format |
lang | string |
a language identifier like fr-fr |
embedPDF? | boolean |
pass true if a PDF version should be embedded into XML output |
pdf? | FileInfo |
the PDF version of the invoice |
data? | FileInfo |
invoice spreadsheet file |
attachments? | FileInfo[] |
an arbitrary number of attachments |
format
This contains the format of the e-invoice as a case-insensitive string. You
can also use aliases. For example, Factur-X-Comfort
is an alias for
Factur-X-EN16931
.
lang
A language identifier like fr-fr
. This is only used for the Factur-X/ZUGFeRD
formats for some canned texts in the PDF XMP meta data.
embedPDF
This is only used for the pure XML formats (everything that is not Factur-X/ZUGFeRD). If it has a truthy value, a PDF version of the invoice is embedded as a base64 encoded string in the XML.
pdf
This is required in two cases:
data
was not specified.embedPDF
was specified and data
was not specified.data
A spreadsheet version of the invoice. If a PDF is required, either because embedPDF was specified for pure XML or because the format is Factur-X/ZUGFeRD, LibreOffice is invoked for rendering the spreadsheet as a PDF.
This feature will trigger an exception if used in the browser.
attachments
You can specify an arbitrary number of additional attachments.
In case of the pure XML formats, they are embedded as base64 encoded strings
in the XML. In case of Factur-X/ZUGFeRD they are attached to the PDF,
additionally to the mandatory attachment factur-x.xml
.
import { FormatFactoryService } from '@e-invoice-eu/core';
const factoryService = new FormatFactoryService();
const formats = factoryService.listFormatServices();
In format
you will find an array of
FormatInfo
objects.
import { invoiceSchema, mappingSchema } from '@e-invoice-eu/core';
These variables contain the schema for the
Invoice
and Mapping
interfaces. These schemas can be passed as an argument to the compile method of an Ajv instance, see https://ajv.js.org/api.html#ajv-compile-schema-object-data-any-boolean-promise-any for more information!
The schemas have the type
JSONSchemaType<Invoice>
and
JSONSchemaType<Mapping>
respectively.
Please report bugs at https://github.com/gflohr/e-invoice-eu/issues.
Copyright (C) 2024-2025 Guido Flohr guido.flohr@cantanea.com, all rights reserved.
This is free software available under the terms of the WTFPL.
This free software has been written with the greatest possible care, but like all software it may contain errors. Use at your own risk! There is no warranty and no liability.