✅ Migration completed: - server.js: Complete rewrite using docxtemplater + pizzip - server-old.js: Backup of original docx-templates implementation - package.json: Added docxtemplater and pizzip dependencies - Removed docx-templates dependency 🚀 New features: - True dynamic tables with {#array}{field}{/array} syntax - Unlimited table rows (no more fixed array indices) - New API endpoints: /analyze, /generate, /demo - Simplified template creation scripts 🎯 Template improvements: - Updated template syntax examples - Added dynamic-template.docx with loop syntax - Enhanced template analysis functionality 📊 Benefits: - Real dynamic table generation - Better template flexibility - Cleaner API design - Preserved SSL and WebDAV functionality
57 lines
3.0 KiB
JavaScript
57 lines
3.0 KiB
JavaScript
const fs = require('fs');
|
|
const path = require('path');
|
|
const { Document, Packer, Paragraph, TextRun, Table, TableRow, TableCell } = require('docx');
|
|
|
|
async function createHybridDynamicTemplate() {
|
|
const doc = new Document({
|
|
sections: [{
|
|
properties: {},
|
|
children: [
|
|
new Paragraph({
|
|
children: [new TextRun({ text: "HYBRID DYNAMISCHE TABELLEN", bold: true, size: 32 })],
|
|
}),
|
|
new Paragraph({ children: [new TextRun({ text: "" })] }),
|
|
new Paragraph({ children: [new TextRun({ text: "Projekt: ++projekt++" })] }),
|
|
new Paragraph({ children: [new TextRun({ text: "Datum: ++datum++" })] }),
|
|
new Paragraph({ children: [new TextRun({ text: "" })] }),
|
|
new Paragraph({ children: [new TextRun({ text: "MITARBEITER:", bold: true, size: 24 })] }),
|
|
new Table({
|
|
rows: [
|
|
// Header Row
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({ children: [new Paragraph({ children: [new TextRun({ text: "Nr.", bold: true })] })] }),
|
|
new TableCell({ children: [new Paragraph({ children: [new TextRun({ text: "Name", bold: true })] })] }),
|
|
new TableCell({ children: [new Paragraph({ children: [new TextRun({ text: "Position", bold: true })] })] }),
|
|
new TableCell({ children: [new Paragraph({ children: [new TextRun({ text: "E-Mail", bold: true })] })] }),
|
|
],
|
|
}),
|
|
// Bis zu 10 dynamische Zeilen (werden server-seitig gefüllt/leer gelassen)
|
|
...Array.from({length: 10}, (_, i) =>
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({ children: [new Paragraph(`++mitarbeiter[${i}].nr++`)] }),
|
|
new TableCell({ children: [new Paragraph(`++mitarbeiter[${i}].name++`)] }),
|
|
new TableCell({ children: [new Paragraph(`++mitarbeiter[${i}].position++`)] }),
|
|
new TableCell({ children: [new Paragraph(`++mitarbeiter[${i}].email++`)] }),
|
|
],
|
|
})
|
|
)
|
|
],
|
|
}),
|
|
new Paragraph({ children: [new TextRun({ text: "" })] }),
|
|
new Paragraph({ children: [new TextRun({ text: "Status: ++status++" })] }),
|
|
],
|
|
}],
|
|
});
|
|
|
|
const buffer = await Packer.toBuffer(doc);
|
|
const templatePath = path.join(__dirname, 'templates', 'tabellen-template.docx');
|
|
fs.writeFileSync(templatePath, buffer);
|
|
|
|
console.log('✅ Hybrid-dynamisches Template erstellt (bis zu 10 Zeilen)');
|
|
console.log('📋 Server füllt nur gewünschte Anzahl, Rest bleibt leer');
|
|
}
|
|
|
|
createHybridDynamicTemplate().catch(console.error);
|