410 lines
11 KiB
TypeScript
410 lines
11 KiB
TypeScript
// Example of how you would merge cells together (Rows and Columns) and apply shading
|
|
// Also includes an example on how to center tables
|
|
|
|
import * as fs from "fs";
|
|
import {
|
|
AlignmentType,
|
|
BorderStyle,
|
|
convertInchesToTwip,
|
|
Document,
|
|
HeadingLevel,
|
|
Packer,
|
|
Paragraph,
|
|
ShadingType,
|
|
Table,
|
|
TableCell,
|
|
TableRow,
|
|
WidthType,
|
|
} from "docx";
|
|
|
|
const table = new Table({
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("Hello")],
|
|
columnSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [],
|
|
}),
|
|
new TableCell({
|
|
children: [],
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
});
|
|
|
|
const table2 = new Table({
|
|
alignment: AlignmentType.CENTER,
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("World")],
|
|
margins: {
|
|
top: convertInchesToTwip(0.69),
|
|
bottom: convertInchesToTwip(0.69),
|
|
left: convertInchesToTwip(0.69),
|
|
right: convertInchesToTwip(0.69),
|
|
},
|
|
columnSpan: 3,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [],
|
|
}),
|
|
new TableCell({
|
|
children: [],
|
|
}),
|
|
new TableCell({
|
|
children: [],
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
width: {
|
|
size: 100,
|
|
type: WidthType.AUTO,
|
|
},
|
|
columnWidths: [convertInchesToTwip(0.69), convertInchesToTwip(0.69), convertInchesToTwip(0.69)],
|
|
});
|
|
|
|
const table3 = new Table({
|
|
alignment: AlignmentType.CENTER,
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("Foo")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("v")],
|
|
columnSpan: 3,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("Bar1")],
|
|
shading: {
|
|
fill: "b79c2f",
|
|
type: ShadingType.REVERSE_DIAGONAL_STRIPE,
|
|
color: "auto",
|
|
},
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("Bar2")],
|
|
shading: {
|
|
fill: "42c5f4",
|
|
type: ShadingType.PERCENT_95,
|
|
color: "auto",
|
|
},
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("Bar3")],
|
|
shading: {
|
|
fill: "880aa8",
|
|
type: ShadingType.PERCENT_10,
|
|
color: "e2df0b",
|
|
},
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("Bar4")],
|
|
shading: {
|
|
fill: "FF0000",
|
|
type: ShadingType.CLEAR,
|
|
color: "auto",
|
|
},
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
width: {
|
|
size: convertInchesToTwip(4.86),
|
|
type: WidthType.DXA,
|
|
},
|
|
margins: {
|
|
top: convertInchesToTwip(0.27),
|
|
bottom: convertInchesToTwip(0.27),
|
|
right: convertInchesToTwip(0.27),
|
|
left: convertInchesToTwip(0.27),
|
|
},
|
|
});
|
|
|
|
const table4 = new Table({
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("0,0")],
|
|
columnSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("1,0")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("1,1")],
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("2,0")],
|
|
columnSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
width: {
|
|
size: 100,
|
|
type: WidthType.PERCENTAGE,
|
|
},
|
|
});
|
|
|
|
const table5 = new Table({
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("0,0")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("0,1")],
|
|
rowSpan: 2,
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("0,2")],
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("1,0")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("1,2")],
|
|
rowSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("2,0")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("2,1")],
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
width: {
|
|
size: 100,
|
|
type: WidthType.PERCENTAGE,
|
|
},
|
|
});
|
|
|
|
const borders = {
|
|
top: {
|
|
style: BorderStyle.DASH_SMALL_GAP,
|
|
size: 1,
|
|
color: "FF0000",
|
|
},
|
|
bottom: {
|
|
style: BorderStyle.DASH_SMALL_GAP,
|
|
size: 1,
|
|
color: "FF0000",
|
|
},
|
|
left: {
|
|
style: BorderStyle.DASH_SMALL_GAP,
|
|
size: 1,
|
|
color: "FF0000",
|
|
},
|
|
right: {
|
|
style: BorderStyle.DASH_SMALL_GAP,
|
|
size: 1,
|
|
color: "FF0000",
|
|
},
|
|
};
|
|
|
|
const table6 = new Table({
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
borders,
|
|
children: [new Paragraph("0,0")],
|
|
rowSpan: 2,
|
|
}),
|
|
new TableCell({
|
|
borders,
|
|
children: [new Paragraph("0,1")],
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
borders,
|
|
children: [new Paragraph("1,1")],
|
|
rowSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
borders,
|
|
children: [new Paragraph("2,0")],
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
width: {
|
|
size: 100,
|
|
type: WidthType.PERCENTAGE,
|
|
},
|
|
});
|
|
|
|
const table7 = new Table({
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("0,0")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("0,1")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("0,2")],
|
|
rowSpan: 2,
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("0,3")],
|
|
rowSpan: 3,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("1,0")],
|
|
columnSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("2,0")],
|
|
columnSpan: 2,
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("2,2")],
|
|
rowSpan: 2,
|
|
}),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({
|
|
children: [new Paragraph("3,0")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("3,1")],
|
|
}),
|
|
new TableCell({
|
|
children: [new Paragraph("3,3")],
|
|
}),
|
|
],
|
|
}),
|
|
],
|
|
width: {
|
|
size: 100,
|
|
type: WidthType.PERCENTAGE,
|
|
},
|
|
});
|
|
|
|
const table8 = new Table({
|
|
rows: [
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({ children: [new Paragraph("1,1")] }),
|
|
new TableCell({ children: [new Paragraph("1,2")] }),
|
|
new TableCell({ children: [new Paragraph("1,3")] }),
|
|
new TableCell({ children: [new Paragraph("1,4")], rowSpan: 4, borders }),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({ children: [new Paragraph("2,1")] }),
|
|
new TableCell({ children: [new Paragraph("2,2")] }),
|
|
new TableCell({ children: [new Paragraph("2,3")], rowSpan: 3 }),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [
|
|
new TableCell({ children: [new Paragraph("3,1")] }),
|
|
new TableCell({ children: [new Paragraph("3,2")], rowSpan: 2 }),
|
|
],
|
|
}),
|
|
new TableRow({
|
|
children: [new TableCell({ children: [new Paragraph("4,1")] })],
|
|
}),
|
|
],
|
|
width: {
|
|
size: 100,
|
|
type: WidthType.PERCENTAGE,
|
|
},
|
|
});
|
|
const doc = new Document({
|
|
sections: [
|
|
{
|
|
children: [
|
|
table,
|
|
new Paragraph({
|
|
text: "Another table",
|
|
heading: HeadingLevel.HEADING_2,
|
|
}),
|
|
table2,
|
|
new Paragraph({
|
|
text: "Another table",
|
|
heading: HeadingLevel.HEADING_2,
|
|
}),
|
|
table3,
|
|
new Paragraph("Merging columns 1"),
|
|
table4,
|
|
new Paragraph("Merging columns 2"),
|
|
table5,
|
|
new Paragraph("Merging columns 3"),
|
|
table6,
|
|
new Paragraph("Merging columns 4"),
|
|
table7,
|
|
new Paragraph("Merging columns 5"),
|
|
table8,
|
|
],
|
|
},
|
|
],
|
|
});
|
|
|
|
Packer.toBuffer(doc).then((buffer) => {
|
|
fs.writeFileSync("My Document.docx", buffer);
|
|
});
|