All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.docx4j.convert.out.html.TagSingleBox Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 11.4.11
Show newest version
/*
 *  Copyright 2010, Plutext Pty Ltd.
 *   
 *  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 java.io.IOException;
import java.util.HashMap;

import javax.xml.bind.JAXBException;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.TransformerException;

import org.docx4j.XmlUtils;
import org.docx4j.openpackaging.packages.WordprocessingMLPackage;
import org.docx4j.wml.SdtPr;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.w3c.dom.Document;
import org.w3c.dom.DocumentFragment;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.traversal.NodeIterator;
import org.xml.sax.SAXException;

/**
 * 
 * In Word, adjacent paragraphs with the same borders are enclosed in a single border
 * (unless bullets/numbering apply).
 * 
 * Similarly with shading.  (If the 2 paragraphs are shaded different colors, then the
 * color of the first extends to the start of the second, so there is no white strip
 * between them).
 * 
 * To do the same in HTML, Containerization puts matching paragraphs into a content
 * control.
 * 
 * It is the job of this class to make a div out of that content control, and 
 * set the border/shading on that as a style, copying the style value from
 * the first paragraph enclosed.
 * 
 * TODO: Note that there will typically be 2 content controls and therefore divs,
 * one for borders and one for shading.  But the style will be the same on
 * each, so one is redundant. 
 * 
 * @author jason
 *
 */
public class TagSingleBox extends SdtTagHandler {

	private static Logger log = LoggerFactory.getLogger(TagSingleBox.class);

	private Element createDiv(Document document, DocumentFragment docfrag, 
			Node n) throws ParserConfigurationException, IOException, SAXException, JAXBException {
		
//		log.debug("Node is: " + n.getNodeName() );

		Element xhtmlDiv = document.createElement("div");
		xhtmlDiv.setAttribute("style", ((Element)n).getAttribute("style") );
		
		docfrag.appendChild(xhtmlDiv);						
    	
		return xhtmlDiv;
	}
	
	private Node getNodeByName(String name, Node n) {
		
		if (n.getNodeType()!=Node.ELEMENT_NODE
				&& n.getNodeType()!=Node.DOCUMENT_NODE) {
			return null;
		}
		
		if (n.getNodeName().equals(name)) {
			return n;
		}
		
		NodeList list = n.getChildNodes();
		for (int i=0; i tagMap,
			NodeIterator childResults) throws TransformerException {

		try {
			// Create a DOM builder and parse the fragment
			Document document = XmlUtils.getNewDocumentBuilder().newDocument();
			DocumentFragment docfrag = document.createDocumentFragment();
			
			Node contents = childResults.nextNode();

			// We want to copy the direct/adhoc formatting from the first p;
			// but that's not a w:p anymore; its an HTML p so ..			
			Node firstP = getNodeByName("p", contents );
			
			Element xhtmlDiv = this.createDiv(document, docfrag, firstP );
									
			return attachContents(docfrag, xhtmlDiv, contents);
			
		} catch (Exception e) {
			throw new TransformerException(e);
		}

	}

		@Override
		public Node toNode(WordprocessingMLPackage wmlPackage, SdtPr sdtPr,
				HashMap tagMap,
				Node resultSoFar) throws TransformerException {
			
			
			try {
				// Create a DOM builder and parse the fragment
				Document document = XmlUtils.getNewDocumentBuilder().newDocument();
				DocumentFragment docfrag = document.createDocumentFragment();
				
				Node contents = resultSoFar;
				Node firstP = getNodeByName("p", contents );
				// NB, this first p could be one which another Handler inserted;
				// caveat emptor.
				
				Element xhtmlDiv = this.createDiv(document, docfrag, firstP );
				
				return attachContents(docfrag, xhtmlDiv, contents);
				
			} catch (Exception e) {
				throw new TransformerException(e);
			}
		}
		
	

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy