diff --git a/src/main/java/w2phtml/xhtml/content/TextParser.java b/src/main/java/w2phtml/xhtml/content/TextParser.java index da33d39..6a03408 100644 --- a/src/main/java/w2phtml/xhtml/content/TextParser.java +++ b/src/main/java/w2phtml/xhtml/content/TextParser.java @@ -267,7 +267,7 @@ public class TextParser extends Parser { if (child.getNodeType() == Node.ELEMENT_NODE) { String nodeName = child.getNodeName(); // Block splitting - //System.out.println(nodeName); + // System.out.println("CURNODE " + nodeName); if (OfficeReader.isDrawElement(child)) { getDrawParser().handleDrawElement((Element)child,(Element)hnode,null,nFloatMode); } @@ -326,7 +326,7 @@ public class TextParser extends Parser { nodeName.equals(TEXT_UNORDERED_LIST) || // old nodeName.equals(TEXT_ORDERED_LIST)) // old { - StyleWithProperties style = getListFirstParaStyle(child); + StyleWithProperties style = getFirstStylePageInfo(child); hnode = processPageBreaks(child, hnode,style); inList = true; if (getListParser().listIsOnlyHeadings(child)) { @@ -348,7 +348,8 @@ public class TextParser extends Parser { getTableParser().handleTable(child,hnode); } else if (nodeName.equals(TEXT_SECTION)) { - hnode = processPageBreaks(child, hnode,null); + StyleWithProperties style = getFirstStylePageInfo(child); + hnode = processPageBreaks(child, hnode,style); hnode = handleSection(child,hnode); } else if (nodeName.equals(TEXT_TABLE_OF_CONTENT)) { @@ -391,24 +392,32 @@ public class TextParser extends Parser { return hnode; } - private StyleWithProperties getListFirstParaStyle(Node list) { + private StyleWithProperties getFirstStylePageInfo(Node node) { StyleWithProperties style = null; - Element listItem = Misc.getChildByTagName(list, TEXT_LIST_ITEM); - if (listItem == null){ - return style; + if (node.getNodeType() == Node.ELEMENT_NODE) { + if (node.getNodeName().equals(TEXT_P) || node.getNodeName().equals(TEXT_H)) { + style = ofr.getParStyle(Misc.getAttribute(node,TEXT_STYLE_NAME)); + return style; + } else if (node.getNodeName().equals(TABLE_TABLE)) { + style = ofr.getTableStyle(Misc.getAttribute(node, TABLE_STYLE_NAME)); + return style; + } + if (node.hasChildNodes()) { + int currentNo = 0; + NodeList childNodes = node.getChildNodes(); + while (currentNo < childNodes.getLength()) { + Node childNode = childNodes.item(currentNo); + style = getFirstStylePageInfo(childNode); + if (style != null) { + return style; + } + currentNo++; + } + } } - Element itemChild = Misc.getFirstChildElement(listItem); - if (itemChild == null) { - return style; - } - String itemChildName = itemChild.getNodeName(); - if (!itemChildName.equals(TEXT_H) && !itemChildName.equals(TEXT_P)) { - return style; - } - style = ofr.getParStyle(Misc.getAttribute(itemChild,TEXT_STYLE_NAME)); return style; } - + /* Process a text:section tag (returns current html node) */ private Node handleSection(Node onode, Node hnode) { // Unlike headings, paragraphs and spans, text:display is not attached to the style: @@ -1275,6 +1284,7 @@ public class TextParser extends Parser { private void setPageContainerStyle() { MasterPage mp = ofr.getFullMasterPage(currentMasterPage); + //System.out.println(currentMasterPage); PageLayout layout = ofr.getPageLayout(mp.getPageLayoutName()); String containerStyle = "column-count: " + layout.getColCount() + ";"; pageContainer.setRootStyle(containerStyle);