/************************************************************************ * * IndexConverterBase.java * * Copyright: 2002-2015 by Henrik Just * * This file is part of Writer2LaTeX. * * Writer2LaTeX is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Writer2LaTeX 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Writer2LaTeX. If not, see . * * Version 1.6 (2015-06-16) * */ package writer2latex.xhtml.content; import org.w3c.dom.Element; import org.w3c.dom.Node; import writer2latex.office.OfficeReader; import writer2latex.office.XMLString; import writer2latex.util.Misc; import writer2latex.xhtml.Converter; import writer2latex.xhtml.Parser; import writer2latex.xhtml.StyleInfo; import writer2latex.xhtml.XhtmlConfig; /** This is a base class for conversion of indexes (table of contents, bibliography, alphabetical index, * list of tables, list of figures) */ abstract class IndexParser extends Parser { private String sEpubType; private String sSourceName; /** Construct a new index converter * * @param ofr the office reader used to read the source document * @param config the configuration * @param converter the converter * @param sSourceName the name of the source data element in the index * @param sEpubType the EPUB 3 semantic type of the index */ IndexParser(OfficeReader ofr, XhtmlConfig config, Converter converter, String sSourceName, String sEpubType) { super(ofr,config,converter); this.sSourceName = sSourceName; this.sEpubType = sEpubType; } /** Generate the actual contents of the index * * @param source the index source * @param container an ul element to populate with list items */ abstract void populateIndex(Element source, Element container); /** Handle an index * * @param onode an index node * @param hnode the index will be added to this block HTML node */ void handleIndex(Element onode, Element hnode) { Element source = Misc.getChildByTagName(onode,sSourceName); if (source!=null) { Element container = createContainer(onode, hnode); generateTitle(source, container); generateIndex(source, container); } } // Create a container node for the index private Element createContainer(Element source, Element hnode) { Element container = converter.createElement(converter.isHTML5() ? "section" : "div"); hnode.appendChild(container); converter.addEpubType(container, sEpubType); String sName = source.getAttribute(XMLString.TEXT_NAME); if (sName!=null) { converter.addTarget(container,sName); } String sStyleName = source.getAttribute(XMLString.TEXT_STYLE_NAME); if (sStyleName!=null) { StyleInfo sectionInfo = new StyleInfo(); getSectionSP().readStyle(sStyleName,sectionInfo); writeStyle(sectionInfo,container); } return container; } // Generate the index title and add it to the container private void generateTitle(Element source, Element container) { Node title = Misc.getChildByTagName(source,XMLString.TEXT_INDEX_TITLE_TEMPLATE); if (title!=null) { Element h1 = converter.createElement("h1"); container.appendChild(h1); String sStyleName = Misc.getAttribute(title,XMLString.TEXT_STYLE_NAME); StyleInfo info = new StyleInfo(); info.sTagName = "h1"; getHeadingSP().applyStyle(1, sStyleName, info); writeStyle(info,h1); getTextParser().traversePCDATA(title,h1); } } // Generate the index and add it to the container private void generateIndex(Element source, Element container) { Element ul = converter.createElement("ul"); // TODO: Support column formatting from the index source ul.setAttribute("style", "list-style-type:none;margin:0;padding:0"); container.appendChild(ul); populateIndex(source,ul); } }