org.docx4j.convert.out.html.HTMLExporterVisitorGenerator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of docx4j-core Show documentation
Show all versions of docx4j-core Show documentation
docx4j is a library which helps you to work with the Office Open
XML file format as used in docx
documents, pptx presentations, and xlsx spreadsheets.
/*
Licensed to Plutext Pty Ltd under one or more contributor license agreements.
* This file is part of docx4j.
docx4j is licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.docx4j.convert.out.html;
import org.docx4j.convert.out.common.AbstractVisitorExporterDelegate;
import org.docx4j.convert.out.common.AbstractVisitorExporterDelegate.AbstractVisitorExporterGeneratorFactory;
import org.docx4j.convert.out.common.AbstractVisitorExporterGenerator;
import org.docx4j.convert.out.common.writer.AbstractBrWriter;
import org.docx4j.model.images.WordXmlPictureE10;
import org.docx4j.model.images.WordXmlPictureE20;
import org.docx4j.model.listnumbering.Emulator.ResultTriple;
import org.docx4j.model.styles.StyleTree;
import org.docx4j.model.styles.StyleTree.AugmentedStyle;
import org.docx4j.model.styles.Tree;
import org.docx4j.wml.Br;
import org.docx4j.wml.PPr;
import org.docx4j.wml.RPr;
import org.w3c.dom.Document;
import org.w3c.dom.DocumentFragment;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
public class HTMLExporterVisitorGenerator extends AbstractVisitorExporterGenerator{
public static final AbstractVisitorExporterDelegate.AbstractVisitorExporterGeneratorFactory GENERATOR_FACTORY =
new AbstractVisitorExporterGeneratorFactory() {
@Override
public AbstractVisitorExporterGenerator createInstance(
HTMLConversionContext conversionContext,
Document document, Node parentNode) {
return new HTMLExporterVisitorGenerator(conversionContext, document, parentNode);
}
};
private HTMLExporterVisitorGenerator(HTMLConversionContext conversionContext, Document document, Node parentNode) {
super(conversionContext, document, parentNode);
}
@Override
protected AbstractVisitorExporterGeneratorFactory getFactory() {
return GENERATOR_FACTORY;
}
@Override
protected Element createNode(Document doc, int nodeType) {
switch (nodeType) {
case NODE_BLOCK:
return document.createElement("p");
case NODE_INLINE:
return document.createElement("span");
}
return null;
}
@Override
protected DocumentFragment createImage(int imgType, HTMLConversionContext conversionContext, Object anchorOrInline) {
switch (imgType) {
case IMAGE_E10:
return WordXmlPictureE10.createHtmlImgE10(conversionContext, anchorOrInline);
case IMAGE_E20:
return WordXmlPictureE20.createHtmlImgE20(conversionContext, anchorOrInline);
}
return null;
}
@Override
protected Element handlePPr(HTMLConversionContext conversionContext, PPr pPrDirect, boolean sdt, Element currentParent) {
Element ret = currentParent;
if ( pPrDirect!=null ) {
String pStyleVal=null;
// Set @class
if (pPrDirect.getPStyle()!=null
&& pPrDirect.getPStyle().getVal()!=null) {
pStyleVal = pPrDirect.getPStyle().getVal();
Tree pTree = conversionContext.getStyleTree().getParagraphStylesTree();
org.docx4j.model.styles.Node asn = pTree.get(pStyleVal);
currentParent.setAttribute("class",
StyleTree.getHtmlClassAttributeValue(pTree, asn)
);
}
// Does our pPr contain anything else?
boolean ignoreBorders = true;
StringBuilder inlineStyle = new StringBuilder();
HtmlCssHelper.createCss(conversionContext.getWmlPackage(), pPrDirect, inlineStyle, ignoreBorders, false);
if (!inlineStyle.toString().equals("") ) {
currentParent.setAttribute("style", inlineStyle.toString() );
}
// Numbering
String numberText=null;
String numId=null;
String levelId=null;
if (pPrDirect.getNumPr()!=null) {
numId = pPrDirect.getNumPr().getNumId()==null ? null : pPrDirect.getNumPr().getNumId().getVal().toString();
levelId = pPrDirect.getNumPr().getIlvl()==null ? null : pPrDirect.getNumPr().getIlvl().getVal().toString();
}
ResultTriple triple = org.docx4j.model.listnumbering.Emulator.getNumber(
conversionContext.getWmlPackage(), pStyleVal, numId, levelId);
if (triple==null) {
getLog().debug("computed number ResultTriple was null");
} else {
if (triple.getBullet() != null) {
//numberText = (triple.getBullet() + " ");
numberText = "\u2022 ";
} else if (triple.getNumString() == null) {
getLog().error("computed NumString was null!");
numberText = ("?");
} else {
numberText = (triple.getNumString() + " ");
}
}
if (numberText!=null) {
currentParent.appendChild(document.createTextNode(
numberText + " "));
}
}
return ret;
}
@Override
protected void handleRPr(
HTMLConversionContext conversionContext,
PPr pPrDirect,
RPr rPrDirect, Element currentParent ) {
// Set @class
if ( rPrDirect.getRStyle()!=null) {
String rStyleVal = rPrDirect.getRStyle().getVal();
Tree cTree = conversionContext.getStyleTree().getCharacterStylesTree();
org.docx4j.model.styles.Node asn = cTree.get(rStyleVal);
if (asn==null) {
getLog().warn("No style node for: " + rStyleVal);
} else {
currentParent.setAttribute("class",
StyleTree.getHtmlClassAttributeValue(cTree, asn)
);
}
}
// Does our rPr contain anything else?
StringBuilder inlineStyle = new StringBuilder();
HtmlCssHelper.createCss(conversionContext.getWmlPackage(), rPrDirect, inlineStyle);
if (!inlineStyle.toString().equals("") ) {
currentParent.setAttribute("style", inlineStyle.toString() );
}
}
@Override
protected void handleBr(Br o) {
// Just the usual case (unlike XSL FO, no attempt is made here to manage vertical space)
convertToNode(conversionContext,
o, AbstractBrWriter.WRITER_ID,
document, (currentP != null ? currentP : parentNode));
currentSpan=null;
}
}