Adds demo to show XML StyleId applied to a table
This commit is contained in:
50
demo/48-table-xml-styles.ts
Normal file
50
demo/48-table-xml-styles.ts
Normal file
@ -0,0 +1,50 @@
|
||||
// Example of how you would create a table and add data to it
|
||||
// Import from 'docx' rather than '../build' if you install from npm
|
||||
import * as fs from "fs";
|
||||
import { Document, Packer, Paragraph, Table, TableCell, TableRow, WidthType } from "../build";
|
||||
|
||||
const styles = fs.readFileSync("./demo/assets/custom-styles.xml", "utf-8");
|
||||
const doc = new Document({
|
||||
title: "Title",
|
||||
externalStyles: styles
|
||||
});
|
||||
|
||||
|
||||
// Create a table and pass the XML Style
|
||||
const table = new Table({
|
||||
style: 'MyCustomTableStyle',
|
||||
width: {
|
||||
size: 9070,
|
||||
type: WidthType.DXA
|
||||
},
|
||||
rows: [
|
||||
new TableRow({
|
||||
children: [
|
||||
new TableCell({
|
||||
children: [new Paragraph("Header Colum 1")],
|
||||
}),
|
||||
new TableCell({
|
||||
children: [new Paragraph("Header Colum 2")],
|
||||
}),
|
||||
],
|
||||
}),
|
||||
new TableRow({
|
||||
children: [
|
||||
new TableCell({
|
||||
children: [new Paragraph("Column Content 3")],
|
||||
}),
|
||||
new TableCell({
|
||||
children: [new Paragraph("Column Content 2")],
|
||||
}),
|
||||
],
|
||||
}),
|
||||
],
|
||||
});
|
||||
|
||||
doc.addSection({
|
||||
children: [table],
|
||||
});
|
||||
|
||||
Packer.toBuffer(doc).then((buffer) => {
|
||||
fs.writeFileSync("My Document.docx", buffer);
|
||||
});
|
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user