Dolibarr-Modul: Arbeitsberichte aus Anhängen erstellen, annotieren, als PDF an Rechnungen anhängen
Find a file
Eduard Wisch 0682b6ce37
All checks were successful
Deploy bericht / deploy (push) Has been skipped
Debug: Logging für dol_dir_list Ausgabe in orders.php
2026-04-17 13:05:25 +02:00
.forgejo/workflows feat: Initiales Release Bericht-Modul v1.0.0 [deploy] 2026-04-08 15:18:59 +02:00
admin Keine Browser-Dialoge mehr — eigene dolModal-Helper [deploy] 2026-04-09 15:46:25 +02:00
ajax [deploy] Fix: Foto-URL relativ zu mobile_upload.php (ajax/get_photo.php) 2026-04-13 13:18:32 +02:00
api Debug: Logging für dol_dir_list Ausgabe in orders.php 2026-04-17 13:05:25 +02:00
class Foto-Upload vom Bericht entkoppeln: Fotos landen im Auftragsordner 2026-04-10 13:48:09 +02:00
core/modules Globale Bericht-Liste entfernt — nur PWA-Zugriff 2026-04-16 10:45:23 +02:00
css Bild-Viewer mit Zoom und Swipe-Navigation [deploy] 2026-04-13 13:00:17 +02:00
fonts DolEditor für Notiz + Notiz unter Bild + Hack-Font im PDF [deploy] 2026-04-09 15:25:10 +02:00
js Bild-Viewer mit Zoom und Swipe-Navigation [deploy] 2026-04-13 13:00:17 +02:00
langs feat: Initiales Release Bericht-Modul v1.0.0 [deploy] 2026-04-08 15:18:59 +02:00
lib PDF-Header mit Logo+Titel, Footer mit Seitenzahl, Hack-Font beschreibbar [deploy] 2026-04-09 15:39:42 +02:00
sql Foto-Upload vom Bericht entkoppeln: Fotos landen im Auftragsordner 2026-04-10 13:48:09 +02:00
.gitignore feat: Initiales Release Bericht-Modul v1.0.0 [deploy] 2026-04-08 15:18:59 +02:00
bericht_batch.php PDF-Header mit Logo+Titel, Footer mit Seitenzahl, Hack-Font beschreibbar [deploy] 2026-04-09 15:39:42 +02:00
bericht_card.php Bild-Viewer mit Zoom und Swipe-Navigation [deploy] 2026-04-13 13:00:17 +02:00
bericht_thirdparty.php feat: Phase 1.3 + 1.7 + Schema 1.4/1.5 — Format/Orient + Kunden-Tab 2026-04-08 22:20:09 +02:00
ChangeLog.md feat: Phase 1.3 + 1.7 + Schema 1.4/1.5 — Format/Orient + Kunden-Tab 2026-04-08 22:20:09 +02:00
CLAUDE.md feat: Unterschriften-Härtung + Kundenkarten-API 2026-04-09 08:06:21 +02:00
mobile_upload.php [deploy] PWA Cache-Control Header hinzugefügt 2026-04-13 13:15:33 +02:00
modulebuilder.txt fix: modulebuilder.txt Marker hinzugefügt — Modul erscheint jetzt im Module Builder [deploy] 2026-04-08 15:23:05 +02:00
README.md feat: Initiales Release Bericht-Modul v1.0.0 [deploy] 2026-04-08 15:18:59 +02:00

Bericht — Arbeitsberichte für Dolibarr

Erstellt aus den Anhängen einer Rechnung (oder eines Auftrags / Angebots) einen Arbeitsbericht als PDF. Bilder und PDFs lassen sich im Browser annotieren (Pfeile, Kreise, Rechtecke, Text, Freihand) — der fertige Bericht wird unter Verknüpfte Dokumente der Rechnung abgelegt.

Funktionen

  • Reiter „Bericht" auf Rechnungen, Aufträgen und Angeboten (jeweils per Konstante deaktivierbar)
  • Anhänge-Browser zeigt alle Dateien des aktuellen Dokuments und der direkt verknüpften Objekte (z. B. der Auftrag zur Rechnung)
  • Auswahl per Checkbox — markierte Dateien werden als Seiten in den Bericht übernommen
  • Browser-Editor mit PDF.js + Fabric.js: Pfeile, Kreise, Rechtecke, Freihand, Text, Farbe, Strichstärke, Undo/Redo
  • Seiten-Verwaltung per Drag&Drop (SortableJS): umordnen, löschen, drehen, neue Seiten hochladen
  • Notizen pro Seite — werden im finalen PDF unten auf der Seite gedruckt
  • Deckblatt aus ODT-Vorlage mit Platzhaltern ({auftragsnummer}, {kunde_name}, {datum}, …)
  • ODT-Templates im Admin-Bereich verwaltbar (mehrere Vorlagen, Standard wählbar)
  • Auftragsnummer wird automatisch aus dem Extrafield options_auftragsnummer der Rechnung gezogen
  • Mehrere Berichte pro Dokument möglich
  • Berichte als Entwurf speichern (jederzeit wieder editierbar) oder finalisieren (PDF erzeugen)

Voraussetzungen

  • Dolibarr ≥ 19.0
  • PHP ≥ 7.4
  • TCPDF (in Dolibarr enthalten)
  • FPDI (für PDF-Anhänge in den Bericht zu mergen) — empfohlen, optional
  • LibreOffice headless (für ODT→PDF Konvertierung der Deckblätter)
  • Optional: pdfinfo oder imagick für PDF-Seitenanzahl-Erkennung

Installation

  1. Modul-Verzeichnis nach dolibarr/htdocs/custom/bericht/ (oder per Symlink aus dem Module-Mount-Pfad) kopieren
  2. In Dolibarr unter Konfiguration → Module/Anwendungen das Modul Bericht aktivieren
  3. Beim Aktivieren werden die SQL-Tabellen llx_bericht und llx_bericht_page angelegt
  4. Vorhandene Extrafields auf llx_facture_extrafields (auftragsnummer, angebotsnummer, …) werden erkannt und nicht überschrieben — fehlende werden angelegt
  5. Im Admin-Bereich (/bericht/admin/setup.php) die ODT-Templates hochladen und Standard-Template setzen

Verwendung

  1. Eine Rechnung öffnen (/compta/facture/card.php?id=…)
  2. Reiter Bericht auswählen
  3. + Neuer Bericht klicken — die Auftragsnummer wird automatisch übernommen
  4. Im Editor links die gewünschten Anhänge ankreuzen → Auswahl in Bericht übernehmen
  5. Im mittleren Editor mit den Werkzeugen Pfeile, Texte etc. zeichnen
  6. Seiten rechts per Drag&Drop sortieren, einzelne Seiten löschen, neue Dateien hochladen
  7. Bericht finalisieren — PDF wird erzeugt, Deckblatt aus der ODT-Vorlage gerendert und unter den verknüpften Dokumenten der Rechnung abgelegt

ODT-Template Platzhalter

Platzhalter Inhalt
{auftragsnummer} Aus extrafield options_auftragsnummer der Rechnung
{angebotsnummer} Aus extrafield options_angebotsnummer
{rechnungsnummer} ref der Rechnung
{kunde_name} Name des Kunden (Société)
{kunde_adresse} Adresse des Kunden, mehrzeilig
{datum} Heutiges Datum
{beschreibung} extrafield options_beschreibung
{hinweis} extrafield options_hinweis
{bericht_titel} Titel des Berichts
{ersteller} Login-Name des erstellenden Users

Architektur

bericht/
├── core/modules/modBericht.class.php   Modul-Descriptor, Tabs, Extrafields-Init
├── class/bericht.class.php             Bericht + BerichtPage CRUD
├── lib/bericht.lib.php                 Helper (Anhänge sammeln, Auftragsnr., Templates)
├── bericht_card.php                    Editor-Seite (Tab-Inhalt)
├── admin/setup.php                     Admin: ODT-Templates, Konstanten
├── ajax/                               Endpoints (Token-geschützt)
│   ├── _inc.php                        Gemeinsamer Header
│   ├── add_attachment.php              Anhang als Seite hinzufügen
│   ├── upload_extra.php                Direkter Upload
│   ├── save_annotations.php            Fabric-JSON speichern
│   ├── page_meta.php                   Annotationen + Notiz laden
│   ├── page_image.php                  Seitenbild/PDF ausliefern
│   ├── delete_page.php
│   ├── reorder_pages.php
│   └── generate_pdf.php                Finalisierung: TCPDF + FPDI + ODT-Deckblatt
├── js/
│   ├── editor.js                       PDF.js + Fabric.js Integration
│   └── lib/                            PDF.js, Fabric.js, SortableJS (lokal)
├── css/bericht.css
├── sql/
│   ├── llx_bericht.sql
│   ├── llx_bericht.key.sql
│   ├── llx_bericht_page.sql
│   └── llx_bericht_page.key.sql
└── langs/{de_DE,en_US}/bericht.lang

Lizenz

GPL v3+