com.openhtmltopdf.pdfboxout.DOMUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of openhtmltopdf-pdfbox Show documentation
Show all versions of openhtmltopdf-pdfbox Show documentation
Openhtmltopdf is a CSS 2.1 renderer written in Java. This artifact supports PDF output with Apache PDF-BOX 2.
/*
* {{{ header & license
* Copyright (c) 2006 Wisconsin Court System
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation; either version 2.1
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
* }}}
*/
package com.openhtmltopdf.pdfboxout;
import java.util.ArrayList;
import java.util.List;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class DOMUtil {
public static Element getChild(Element parent, String name) {
NodeList children = parent.getChildNodes();
for (int i = 0; i < children.getLength(); i++) {
Node n = (Node)children.item(i);
if (n.getNodeType() == Node.ELEMENT_NODE) {
Element elem = (Element)n;
if (elem.getTagName().equals(name)) {
return elem;
}
}
}
return null;
}
public static List getChildren(Element parent, String name) {
List result = new ArrayList<>();
NodeList children = parent.getChildNodes();
for (int i = 0; i < children.getLength(); i++) {
Node n = (Node)children.item(i);
if (n.getNodeType() == Node.ELEMENT_NODE) {
Element elem = (Element)n;
if (elem.getTagName().equals(name)) {
result.add(elem);
}
}
}
return result.size() == 0 ? null : result;
}
/**
* Helper function to find an enclosing element with given node name. Returns null on failure.
*/
public static Element findClosestEnclosingElementWithNodeName(Node e, String nodeName) {
Node parent;
while ((parent = e.getParentNode()) != null) {
if (parent.getNodeType() == Node.ELEMENT_NODE &&
parent.getNodeName().equals(nodeName)) {
return (Element) parent;
}
e = parent;
}
return null;
}
/**
* Loads all of the text content in all offspring of an element.
* Ignores all attributes, comments and processing instructions.
*
* @return a String with the text content of an element (may be an empty string but will not be null).
*/
public static String getText(Element parent) {
StringBuilder sb = new StringBuilder();
getText(parent, sb);
return sb.toString();
}
/**
* Appends all text content in all offspring of an element to a StringBuffer.
* Ignores all attributes, comments and processing instructions.
*
* @param sb will get the text content of the element children
*/
public static void getText(Element parent, StringBuilder sb) {
NodeList children = parent.getChildNodes();
for (int i = 0; i < children.getLength(); i++) {
Node n = (Node)children.item(i);
if (n.getNodeType() == Node.ELEMENT_NODE) {
getText((Element)n, sb);
} else if (n.getNodeType() == Node.TEXT_NODE) {
sb.append(n.getNodeValue());
}
}
}
}