<p align="center">
	<img
		src="https://raw.githubusercontent.com/gflohr/e-invoice-eu/main/assets/e-invoice-eu-logo-2.webp"
		width="256" height="256" />
</p>

[![licence](https://img.shields.io/badge/licence-WTFPL-blue)](http://www.wtfpl.net/)
[![price](https://img.shields.io/badge/price-FREE-green)](https://github.com/gflohr/e-invoice-eu/blob/main/LICENSE)
[![coverage](https://img.shields.io/coverallsCoverage/github/gflohr/e-invoice-eu?branch=main)](https://coveralls.io/github/gflohr/e-invoice-eu?branch=main)
[![downloads](https://img.shields.io/npm/dw/%40e-invoice-eu%2Fcore)](https://www.npmjs.com/package/@e-invoice-eu/core)
[![documentation](https://img.shields.io/badge/documentation-read-green)](https://gflohr.github.io/e-invoice-eu)
[![help](https://img.shields.io/badge/help-ask--a--question-green)](https://notebooklm.google.com/notebook/f5783dde-ebe6-4610-bac1-f181fdf45f94)
[![listed on](https://img.shields.io/badge/listed%20on-awesome--europe-ffcc00?logo=europeanunion&logoColor=ffcc00&labelColor=003399)](https://github.com/GeiserX/awesome-europe#readme)
[![stand with](https://img.shields.io/badge/stand%20with-Ukraine🇺🇦-ffc107)](https://www.standwithukraineeurope.com/en/)

# E-Invoice-EU<!-- omit from toc -->

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](https://github.com/gflohr/e-invoice-eu/tree/main/apps/cli)
and the [E-Invoice-EU web service](https://github.com/gflohr/e-invoice-eu/tree/main/apps/server)
use it as their foundation.

## Table of Contents<!-- omit from toc -->

- [Features](#features)
- [Documentation](#documentation)
- [Installation](#installation)
- [Usage](#usage)
	- [Importing/Requiring the Library](#importingrequiring-the-library)
	- [Creating Invoice Data from Spreadsheet Files](#creating-invoice-data-from-spreadsheet-files)
	- [Generating an Invoice from Data in the Internal Format](#generating-an-invoice-from-data-in-the-internal-format)
		- [Argument `format`](#argument-format)
		- [Argument `lang`](#argument-lang)
		- [Argument `embedPDF`](#argument-embedpdf)
		- [Argument `pdf`](#argument-pdf)
		- [Argument `data`](#argument-data)
		- [Argument `attachments`](#argument-attachments)
	- [Getting Supported Formats](#getting-supported-formats)
	- [Getting the JSON Schema Definitions](#getting-the-json-schema-definitions)
- [Reporting Bugs](#reporting-bugs)
- [Copyright](#copyright)
- [Disclaimer](#disclaimer)

## Features

The library can create e-invoices in the following formats:

- Cross Industry Invoice - CII
- Universal Business Language - UBL
- Factur-X/ZUGFeRD (all profiles including XRECHNUNG) with full PDF/A support

E-Invoices can be created directly from data in the [E-Invoice-EU internal
format](https://gflohr.github.io/e-invoice-eu/en/docs/details/internal-format/)
or via a [mapping definition](https://gflohr.github.io/e-invoice-eu/en/docs/details/mapping/)
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.

## Documentation

The general documentation of `e-invoice-eu` is available at the
[`e-invoice-eu` GitHub page](https://github.com/gflohr/e-invoice-eu/tree/main/packages/core).
For reference, you can also consult the
[API documentation](https://gflohr.github.io/e-invoice-eu/api-docs/).

## Installation

```sh
npm install @e-invoice-eu/core
```

## Usage

### Importing/Requiring the Library

If you have the `import` keyword:

```typescript
import { InvoiceService, MappingService } from '@e-invoice-eu/core';
```

With `require`:

```javascript
const { InvoiceService, MappingService } = require('@e-invoice-eu/core');
```

In the browser:

```html
<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>
```

### Creating Invoice Data from Spreadsheet Files

For this optional step, you need both the spreadsheet file as a `Buffer` and a
mapping definition as a
[`Mapping`](https://gflohr.github.io/e-invoice-eu/api-docs/interfaces/Mapping.html)
object:

```typescript
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`](https://gflohr.github.io/e-invoice-eu/api-docs/interfaces/Invoice.html)
instance in the internal format. It is not yet an XML string or PDF buffer!

### Generating an Invoice from Data in the Internal Format

You can either provide the invoice data yourself as an
[`Invoice`](https://gflohr.github.io/e-invoice-eu/api-docs/interfaces/Invoice.html)
instance or you can create it from spreadsheet data and a mapping definition
as shown in the [previous section](#creating-invoice-data-from-spreadsheet-files).

```typescript
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](https://gflohr.github.io/e-invoice-eu/en/docs/basics/supported-formats/) |
| lang         | `string`                                                                           | a language identifier like `fr-fr`                                                            |
| embedPDF?    | `boolean`                                                                          | pass `true` if a PDF version should be embedded into XML output                               |
| pdf?         | [`FileInfo`](https://gflohr.github.io/e-invoice-eu/api-docs/types/FileInfo.html)   | the PDF version of the invoice                                                                |
| data?        | [`FileInfo`](https://gflohr.github.io/e-invoice-eu/api-docs/types/FileInfo.html)   | invoice spreadsheet file                                                                      |
| attachments? | [`FileInfo[]`](https://gflohr.github.io/e-invoice-eu/api-docs/types/FileInfo.html) | an arbitrary number of attachments                                                            |

#### Argument `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`.

#### Argument `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.

#### Argument `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.

#### Argument `pdf`

This is required in two cases:

1. The format is a Factur-X/ZUGFeRD format and `data` was **not** specified.
2. The format is a pure XML format, `embedPDF` was specified and `data` was not specified.

#### Argument `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](https://libreoffice.org) is invoked for rendering the spreadsheet
as a PDF.

This feature will trigger an exception if used in the browser.

#### Argument `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`.

### Getting Supported Formats

```typescript
import { FormatFactoryService } from '@e-invoice-eu/core';

const factoryService = new FormatFactoryService();
const formats = factoryService.listFormatServices();
```

In `format` you will find an array of
[`FormatInfo`](https://gflohr.github.io/e-invoice-eu/api-docs/types/FormatInfo.html)
objects.

### Getting the JSON Schema Definitions

```typescript
import { invoiceSchema, mappingSchema } from '@e-invoice-eu/core';
```

These variables contain the schema for the
[`Invoice`](https://gflohr.github.io/e-invoice-eu/api-docs/types/Invoice.html)
and [`Mapping`](https://gflohr.github.io/e-invoice-eu/api-docs/types/Mapping.html)
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>`](https://ajv.js.org/guide/typescript.html#utility-types-for-schemas)
and
[`JSONSchemaType<Mapping>`](https://ajv.js.org/guide/typescript.html#utility-types-for-schemas)
respectively.

## Reporting Bugs

Please report bugs at https://github.com/gflohr/e-invoice-eu/issues.

## Copyright

Copyright (C) 2024-2026 Guido Flohr <guido.flohr@cantanea.com>, all
rights reserved.

This is free software available under the terms of the
[WTFPL](http://www.wtfpl.net/).

## Disclaimer

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.
