105 lines
2.2 KiB
TypeScript
105 lines
2.2 KiB
TypeScript
import {XmlComponent, Attributes} from "../xml-components";
|
|
import {ThematicBreak} from "./border";
|
|
import {PageBreak} from "./page-break";
|
|
import {TextRun} from "./text-run";
|
|
import {ParagraphProperties} from "./properties";
|
|
|
|
class Style {
|
|
private pStyle: Array<XmlComponent>;
|
|
|
|
constructor(type: string) {
|
|
this.pStyle = new Array<XmlComponent>();
|
|
this.pStyle.push(new Attributes({
|
|
val: type
|
|
}));
|
|
}
|
|
}
|
|
|
|
class Alignment {
|
|
private jc: Array<XmlComponent>;
|
|
|
|
constructor(type: string) {
|
|
this.jc = new Array<XmlComponent>();
|
|
this.jc.push(new Attributes({
|
|
val: type
|
|
}));
|
|
}
|
|
}
|
|
|
|
export class Paragraph {
|
|
private p: Array<XmlComponent>;
|
|
private properties: ParagraphProperties;
|
|
|
|
constructor(text?: string) {
|
|
this.p = new Array<XmlComponent>();
|
|
this.p.push(new Attributes());
|
|
this.properties = new ParagraphProperties();
|
|
this.p.push(this.properties);
|
|
this.p.push(new TextRun(text));
|
|
}
|
|
|
|
addText(run: TextRun) {
|
|
this.p.push(run);
|
|
return this;
|
|
}
|
|
|
|
heading1() {
|
|
this.properties.push(new Style("Heading1"));
|
|
return this;
|
|
}
|
|
|
|
heading2() {
|
|
this.properties.push(new Style("Heading2"));
|
|
return this;
|
|
}
|
|
|
|
heading3() {
|
|
this.properties.push(new Style("Heading3"));
|
|
return this;
|
|
}
|
|
|
|
heading4() {
|
|
this.properties.push(new Style("Heading4"));
|
|
return this;
|
|
}
|
|
|
|
heading5() {
|
|
this.properties.push(new Style("Heading5"));
|
|
return this;
|
|
}
|
|
|
|
title() {
|
|
this.properties.push(new Style("Title"));
|
|
return this;
|
|
}
|
|
|
|
center() {
|
|
this.properties.push(new Alignment("center"));
|
|
return this;
|
|
}
|
|
|
|
left() {
|
|
this.properties.push(new Alignment("left"));
|
|
return this;
|
|
}
|
|
|
|
right() {
|
|
this.properties.push(new Alignment("right"));
|
|
return this;
|
|
}
|
|
|
|
justified() {
|
|
this.properties.push(new Alignment("both"));
|
|
return this;
|
|
}
|
|
|
|
thematicBreak() {
|
|
this.properties.push(new ThematicBreak());
|
|
return this;
|
|
}
|
|
|
|
pageBreak() {
|
|
this.properties.push(new PageBreak());
|
|
return this;
|
|
}
|
|
} |