refactoring
This commit is contained in:
parent
dbdf7ca2a5
commit
a93679a41b
1 changed files with 34 additions and 36 deletions
|
@ -453,26 +453,24 @@ public class PageSplitter {
|
|||
}
|
||||
return dataMoved;
|
||||
}
|
||||
private static boolean handleSection(Node sectionFirstPart, Node sectionNode) {
|
||||
private static boolean handleSection(Node sectionFirstPart, Node section) {
|
||||
boolean dataMoved = false;
|
||||
// Node counter
|
||||
int i = 0;
|
||||
NodeList sectionChildNodes = sectionNode.getChildNodes();
|
||||
while (sectionChildNodes.getLength() > i) {
|
||||
NodeList sectionChilds = section.getChildNodes();
|
||||
while (sectionChilds.getLength() > i) {
|
||||
|
||||
Node sectionChildNode = sectionChildNodes.item(0);
|
||||
if ((sectionChildNode.getNodeType() == Node.ELEMENT_NODE)) {
|
||||
String nodeName = sectionChildNode.getNodeName();
|
||||
// System.out.println("Nodename " + nodeName);
|
||||
if (containsSPB(sectionChildNode)){
|
||||
// System.out.println("Contains spb");
|
||||
Node sectionChildFirstPart = sectionChildNode.cloneNode(false);
|
||||
Node child = sectionChilds.item(0);
|
||||
if ((child.getNodeType() == Node.ELEMENT_NODE)) {
|
||||
String nodeName = child.getNodeName();
|
||||
if (containsSPB(child)){
|
||||
Node childFirstPart = child.cloneNode(false);
|
||||
if (nodeName.equals(TEXT_SOFT_PAGE_BREAK)){
|
||||
// remove inner soft page break node
|
||||
sectionNode.removeChild(sectionChildNode);
|
||||
section.removeChild(child);
|
||||
|
||||
} else if (nodeName.equals(TEXT_H) || nodeName.equals(TEXT_P)) {
|
||||
Node paraFirstPart = handleParagraph(sectionChildNode);
|
||||
Node paraFirstPart = handleParagraph(child);
|
||||
if (paraFirstPart != null){
|
||||
sectionFirstPart.appendChild(paraFirstPart);
|
||||
dataMoved=true;
|
||||
|
@ -480,34 +478,34 @@ public class PageSplitter {
|
|||
} else if (nodeName.equals(TEXT_TABLE_OF_CONTENT)) {
|
||||
|
||||
//HACK
|
||||
removeSPB(sectionNode);
|
||||
removeSPB(section);
|
||||
i++;
|
||||
continue;
|
||||
} else if (nodeName.equals(TABLE_TABLE)) {
|
||||
if (handleTableTable(sectionChildFirstPart, sectionChildNode)){
|
||||
sectionFirstPart.appendChild(sectionChildFirstPart);
|
||||
if (handleTableTable(childFirstPart, child)){
|
||||
sectionFirstPart.appendChild(childFirstPart);
|
||||
dataMoved=true;
|
||||
}
|
||||
} else if (nodeName.equals(TEXT_SECTION)) {
|
||||
if (handleSection(sectionChildFirstPart, sectionChildNode)){
|
||||
sectionFirstPart.appendChild(sectionChildFirstPart);
|
||||
if (handleSection(childFirstPart, child)){
|
||||
sectionFirstPart.appendChild(childFirstPart);
|
||||
dataMoved=true;
|
||||
}
|
||||
} else if (nodeName.equals(TEXT_LIST)) {
|
||||
if (handleList(sectionChildFirstPart, sectionChildNode)){
|
||||
sectionFirstPart.appendChild(sectionChildFirstPart);
|
||||
if (handleList(childFirstPart, child)){
|
||||
sectionFirstPart.appendChild(childFirstPart);
|
||||
dataMoved=true;
|
||||
}
|
||||
}
|
||||
//split node with spb and exit
|
||||
break;
|
||||
} else {
|
||||
sectionFirstPart.appendChild(sectionChildNode);
|
||||
sectionFirstPart.appendChild(child);
|
||||
dataMoved = true;
|
||||
}
|
||||
} else {
|
||||
//Append text nodes
|
||||
sectionFirstPart.appendChild(sectionChildNode);
|
||||
sectionFirstPart.appendChild(child);
|
||||
dataMoved = true;
|
||||
}
|
||||
|
||||
|
@ -521,17 +519,17 @@ public class PageSplitter {
|
|||
Node paraBefore = para.cloneNode(false);
|
||||
boolean dataMoved = false;
|
||||
int i = 0;
|
||||
NodeList paraChildNodes = para.getChildNodes();
|
||||
while (paraChildNodes.getLength() > i) {
|
||||
Node paraChildNode = paraChildNodes.item(i);
|
||||
NodeList сhilds = para.getChildNodes();
|
||||
while (сhilds.getLength() > i) {
|
||||
Node сhild = сhilds.item(i);
|
||||
//NOT TEXT NODES
|
||||
if ((paraChildNode.getNodeType() == Node.ELEMENT_NODE)) {
|
||||
String nodeName = paraChildNode.getNodeName();
|
||||
if ((сhild.getNodeType() == Node.ELEMENT_NODE)) {
|
||||
String childName = сhild.getNodeName();
|
||||
//SPB FOUND
|
||||
if (containsSPB(paraChildNode)){
|
||||
if (nodeName.equals(TEXT_SOFT_PAGE_BREAK)){
|
||||
if (containsSPB(сhild)){
|
||||
if (childName.equals(TEXT_SOFT_PAGE_BREAK)){
|
||||
//Next node in paragraph. If it is text node go further
|
||||
Node paraNextNode = paraChildNodes.item(i+1);
|
||||
Node paraNextNode = сhilds.item(i+1);
|
||||
Node paraPrevNode = paraBefore.getLastChild();
|
||||
String nextText = null;
|
||||
String prevText = null;
|
||||
|
@ -568,34 +566,34 @@ public class PageSplitter {
|
|||
if (paraNextNode == null && paraPrevNode == null){
|
||||
Document doc = para.getOwnerDocument();
|
||||
Node space = doc.createTextNode(" ");
|
||||
para.insertBefore(space, paraChildNode);
|
||||
para.insertBefore(space, сhild);
|
||||
}
|
||||
|
||||
// remove inner soft page break node
|
||||
para.removeChild(paraChildNode);
|
||||
para.removeChild(сhild);
|
||||
|
||||
/* Check if next node in para is text and first char is a letter
|
||||
* Check if last node in paraFirstPart is text and last char is a letter
|
||||
* If both true - add
|
||||
*/
|
||||
} else {
|
||||
System.out.println("ERROR: SPB INSIDE Paragraph Element in inner element " + nodeName);
|
||||
System.out.println("ERROR: SPB INSIDE Paragraph Element in inner element " + childName);
|
||||
//checkSoftPageBreak(internalNode, true);
|
||||
//paraFirstPart.appendChild(internalNode);
|
||||
//dataMoved = true;
|
||||
}
|
||||
break;
|
||||
//ELEMENT WITHOUT SPB
|
||||
} else if (nodeName.equals(TEXT_BOOKMARK_START)){
|
||||
paraBefore.appendChild(paraChildNode.cloneNode(true));
|
||||
} else if (childName.equals(TEXT_BOOKMARK_START)){
|
||||
paraBefore.appendChild(сhild.cloneNode(true));
|
||||
i++;
|
||||
} else {
|
||||
paraBefore.appendChild(paraChildNode);
|
||||
paraBefore.appendChild(сhild);
|
||||
dataMoved = true;
|
||||
}
|
||||
//TEXT NODES
|
||||
} else {
|
||||
paraBefore.appendChild(paraChildNode);
|
||||
paraBefore.appendChild(сhild);
|
||||
dataMoved = true;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue