Server : Apache/2.4.43 (Win64) OpenSSL/1.1.1g PHP/7.4.6 System : Windows NT USER-PC 6.1 build 7601 (Windows 7 Professional Edition Service Pack 1) AMD64 User : User ( 0) PHP Version : 7.4.6 Disable Function : NONE Directory : C:/Program Files (x86)/OpenOffice 4/share/xslt/export/xhtml/ |
<?xml version="1.0" encoding="UTF-8"?> <!--*********************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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. * ***********************************************************--> <!-- For further documentation and updates visit http://xml.openoffice.org/odf2xhtml --> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" xmlns:ooo="http://openoffice.org/2004/office" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:xforms="http://www.w3.org/2002/xforms" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xt="http://www.jclark.com/xt" xmlns:common="http://exslt.org/common" xmlns:xalan="http://xml.apache.org/xalan" exclude-result-prefixes="chart config dc dom dr3d draw fo form math meta number office ooo oooc ooow script style svg table text xforms xlink xsd xsi xt common xalan" xmlns="http://www.w3.org/1999/xhtml"> <!--+++++ INCLUDED XSL MODULES +++++--> <!-- helper collection, to convert measures (e.g. inch to pixel using DPI (dots per inch) parameter)--> <xsl:import href="../../common/measure_conversion.xsl"/> <!-- common office body element handling --> <xsl:import href="../common/body.xsl"/> <!-- common table handling --> <xsl:import href="../common/table/table.xsl"/> <!-- xhtml table handling --> <xsl:include href="table.xsl"/> <!-- Useful in case of 'style:map', conditional formatting, where a style references to another --> <xsl:key name="styles" match="/*/office:styles/style:style | /*/office:automatic-styles/style:style" use="@style:name"/> <!-- ************ --> <!-- *** body *** --> <!-- ************ --> <xsl:key match="style:style/@style:master-page-name" name="masterPage" use="'count'"/> <xsl:key match="style:master-page" name="masterPageElements" use="@style:name"/> <xsl:key match="style:page-layout" name="pageLayoutElements" use="@style:name"/> <xsl:key name="writingModeStyles" match="/*/office:styles/style:style/style:paragraph-properties/@style:writing-mode | /*/office:automatic-styles/style:style/style:paragraph-properties/@style:writing-mode" use="'test'"/> <xsl:template name="create-body"> <xsl:param name="globalData"/> <xsl:call-template name="create-body.collect-page-properties"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:template> <xsl:template name="create-body.collect-page-properties"> <xsl:param name="globalData"/> <!-- approximation to find the correct master page style (with page dimensions) --> <xsl:variable name="masterPageNames"> <!-- Loop over every style:style containing a @style:master-page-name attribute --> <xsl:for-each select="key('masterPage','count')"> <!-- Check if this style is being used in the body --> <xsl:if test="key('elementUsingStyle', ../@style:name)"> <!-- Check every master-page-name if it is not emtpy and return as ';' separated list --> <xsl:if test="string-length(../@style:master-page-name) > 0"> <xsl:value-of select="../@style:master-page-name"/>; </xsl:if> </xsl:if> </xsl:for-each> </xsl:variable> <!-- Take the first of the masterpage list and get the according style:master-page element and find the @style:page-layout-name --> <xsl:variable name="pageLayoutName" select="key('masterPageElements', substring-before($masterPageNames,';'))/@style:page-layout-name"/> <xsl:variable name="pagePropertiesRTF"> <xsl:choose> <xsl:when test="not($pageLayoutName) or $pageLayoutName = ''"> <xsl:copy-of select="$globalData/styles-file/*/office:automatic-styles/style:page-layout[1]/style:page-layout-properties"/> </xsl:when> <xsl:otherwise> <!-- Find the according style:page-layout and store the properties in a variable --> <xsl:copy-of select="key('pageLayoutElements', $pageLayoutName)/style:page-layout-properties"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:choose> <xsl:when test="function-available('common:node-set')"> <xsl:call-template name="create-body.create"> <xsl:with-param name="globalData" select="common:node-set($globalData)"/> <xsl:with-param name="pageProperties" select="common:node-set($pagePropertiesRTF)"/> </xsl:call-template> </xsl:when> <xsl:when test="function-available('xalan:nodeset')"> <xsl:call-template name="create-body.create"> <xsl:with-param name="globalData" select="xalan:nodeset($globalData)"/> <xsl:with-param name="pageProperties" select="xalan:nodeset($pagePropertiesRTF)"/> </xsl:call-template> </xsl:when> <xsl:when test="function-available('xt:node-set')"> <xsl:call-template name="create-body.create"> <xsl:with-param name="globalData" select="xt:node-set($globalData)"/> <xsl:with-param name="pageProperties" select="xt:node-set($pagePropertiesRTF)"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:message terminate="yes">The required node-set function was not found!</xsl:message> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="create-body.create"> <xsl:param name="globalData"/> <xsl:param name="pageProperties"/> <xsl:element name="body"> <!-- direction of text flow --> <xsl:variable name="writingMode" select="$pageProperties/style:page-layout-properties/@style:writing-mode"/> <xsl:choose> <xsl:when test="$writingMode"> <xsl:choose> <xsl:when test="contains($writingMode, 'lr')"> <xsl:attribute name="dir">ltr</xsl:attribute> </xsl:when> <xsl:when test="contains($writingMode, 'rl')"> <xsl:attribute name="dir">rtl</xsl:attribute> </xsl:when> </xsl:choose> </xsl:when> <xsl:otherwise> <!-- As CSS writing-mode is not implemented by all browsers, a heuristic is done --> <xsl:variable name="writingModeTest" select="key('writingModeStyles', 'test')"/> <xsl:if test="contains($writingModeTest, 'rl')"> <xsl:attribute name="dir">rtl</xsl:attribute> </xsl:if> </xsl:otherwise> </xsl:choose> <!-- adapt page size --> <xsl:variable name="pageWidth" select="$pageProperties/style:page-layout-properties/@fo:page-width"/> <!-- multiple backgroundimages for different page styles (never used in html) --> <xsl:variable name="backgroundImage" select="$pageProperties/style:page-layout-properties/style:background-image"/> <!-- page margins & background image --> <xsl:if test="$pageWidth or $pageProperties/style:page-layout-properties/@fo:* or $backgroundImage/@xlink:href"> <xsl:attribute name="style"> <xsl:if test="$pageWidth"> <xsl:text>max-width:</xsl:text> <xsl:value-of select="$pageWidth"/> <xsl:text>;</xsl:text> </xsl:if> <xsl:if test="$pageProperties/style:page-layout-properties/@fo:* or $backgroundImage/@xlink:href"> <xsl:apply-templates select="$pageProperties/style:page-layout-properties/@fo:*"/> <xsl:if test="$backgroundImage/@xlink:href"> <xsl:text>background-image:url(</xsl:text> <xsl:call-template name="create-href"> <xsl:with-param name="href" select="$backgroundImage/@xlink:href"/> </xsl:call-template> <xsl:text>);</xsl:text> <xsl:if test="$backgroundImage/@style:repeat"> <xsl:choose> <xsl:when test="$backgroundImage/@style:repeat = 'no-repeat'"> <xsl:text>background-repeat:no-repeat;</xsl:text> </xsl:when> <xsl:otherwise> <xsl:text>background-repeat:repeat;</xsl:text> </xsl:otherwise> </xsl:choose> </xsl:if> <xsl:if test="$backgroundImage/@style:position"> <xsl:text>background-position:</xsl:text> <xsl:value-of select="$backgroundImage/@style:position"/> <xsl:text>;</xsl:text> </xsl:if> </xsl:if> </xsl:if> </xsl:attribute> </xsl:if> <!-- processing the content of the OpenDocument content file --> <xsl:apply-templates select="/*/office:body/*"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> </xsl:template> <!-- processing the content of the OpenDocument content file --> <xsl:template match="office:body/*"> <xsl:param name="globalData"/> <!-- not using of 'apply-styles-and-content' as the content table information migth have been added to 'globalData' variable --> <xsl:apply-templates select="@text:style-name | @draw:style-name | @draw:text-style-name | @table:style-name"><!-- | @presentation:style-name --> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <!-- writing the footer- and endnotes beyond the body --> <xsl:call-template name="write-text-nodes"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:template> <!-- ******************************* --> <!-- *** User Field Declarations *** --> <!-- ******************************* --> <xsl:template match="text:user-field-get | text:user-field-input"> <xsl:param name="globalData"/> <xsl:value-of select="."/> </xsl:template> <xsl:template match="text:conditional-text"> <xsl:param name="globalData"/> <xsl:value-of select="."/> </xsl:template> <!-- ODF text fields --> <xsl:template match="text:author-initials | text:author-name | text:chapter | text:character-count | text:creation-date | text:creation-time | text:creator | text:date | text:description | text:editing-cycles | text:editing-duration | text:file-name | text:image-count | text:initial-creator | text:keywords | text:modification-date | text:modification-time | text:object-count | text:page-continuation | text:page-count | text:page-number | text:paragraph-count | text:print-date | text:print-time | text:printed-by | text:sender-city | text:sender-company | text:sender-country | text:sender-email | text:sender-fax | text:sender-firstname | text:sender-initials | text:sender-lastname | text:sender-phone-private | text:sender-phone-work | text:sender-position | text:sender-postal-code | text:sender-state-or-province | text:sender-street | text:sender-title | text:sheet-name | text:subject | text:table-count | text:time | text:title | text:user-defined | text:word-count"> <xsl:param name="globalData"/> <xsl:element name="span"> <xsl:attribute name="title"> <xsl:value-of select="local-name()"/> </xsl:attribute> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> </xsl:template> <!-- *************** --> <!-- *** Textbox *** --> <!-- *************** --> <xsl:template match="draw:text-box"> <xsl:param name="globalData"/> <xsl:comment>Next 'div' was a 'draw:text-box'.</xsl:comment> <xsl:element name="div"> <xsl:variable name="dimension"> <xsl:apply-templates select="@fo:min-width"/> <xsl:apply-templates select="@fo:max-width"/> <xsl:apply-templates select="@fo:min-height"/> <xsl:apply-templates select="@fo:max-height"/> </xsl:variable> <xsl:if test="$dimension"> <xsl:attribute name="style"> <xsl:value-of select="$dimension"/> </xsl:attribute> </xsl:if> <xsl:apply-templates select="@draw:name"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <xsl:apply-templates select="node()"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> </xsl:template> <xsl:template match="@fo:min-width"> <xsl:text>min-width:</xsl:text> <xsl:value-of select="."/> <xsl:text>;</xsl:text> </xsl:template> <xsl:template match="@fo:max-width"> <xsl:text>max-width:</xsl:text> <xsl:value-of select="."/> <xsl:text>;</xsl:text> </xsl:template> <xsl:template match="@fo:min-height"> <xsl:text>min-height:</xsl:text> <xsl:value-of select="."/> <xsl:text>;</xsl:text> </xsl:template> <xsl:template match="@fo:max-height"> <xsl:text>max-height:</xsl:text> <xsl:value-of select="."/> <xsl:text>;</xsl:text> </xsl:template> <!-- inline style helper for the 'div' boxes --> <xsl:template name="svg:height"> <xsl:text>height:</xsl:text> <xsl:choose> <!-- changing the distance measure: inch to in --> <xsl:when test="contains(@svg:height, 'inch')"> <xsl:value-of select="substring-before(@svg:height, 'ch')"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="@svg:height"/> </xsl:otherwise> </xsl:choose> <xsl:text>;</xsl:text> </xsl:template> <!-- inline style helper for the 'div' boxes --> <xsl:template name="svg:width"> <xsl:text>width:</xsl:text> <xsl:choose> <!-- changing the distance measure: inch to in --> <xsl:when test="contains(@svg:width, 'inch')"> <xsl:value-of select="substring-before(@svg:width, 'ch')"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="@svg:width"/> </xsl:otherwise> </xsl:choose> <xsl:text>;</xsl:text> </xsl:template> <!-- ****************** --> <!-- *** Paragraphs *** --> <!-- ****************** --> <xsl:template match="text:p | draw:page"> <xsl:param name="globalData"/> <!-- The footnote symbol is the prefix for a footnote in the footer --> <xsl:param name="footnotePrefix"/> <!-- 1) In ODF sometimes the followig children are nested <text:p> <draw:frame> <draw:text-box> <text:p> Which results in a paragraphs (the last text:p) having a paragraph as its anchestor. In HTML a 'p' can only have inline documents (no other 'p' as children'), a 'div' will be given for the ancestors instead. 2) ODF images are embedded in a paragraph, but CSS is not able to express a horizontal alignment for an HTML image (text:align is only valid for block elements). A surrounding 'div' element taking over the image style solves that problem, but the div is invalid as child of a paragraph Therefore the paragraph has to be exchanged with a HTML div element --> <!-- 2DO page alignment fix - PART1 --> <xsl:variable name="childText"><xsl:apply-templates mode="getAllTextChildren"/></xsl:variable> <xsl:choose> <xsl:when test="name() = 'text:p' and not(*) and (normalize-space($childText) = '')"> <!-- WorkAround: Test if the empty paragraph was added after an image, which OOO often does --> <xsl:variable name="isFollowingImage"> <xsl:call-template name="follows-empty-paragraphs-and-image"> <xsl:with-param name="precedingElement" select="preceding-sibling::node()[1]"/> </xsl:call-template> </xsl:variable> <xsl:if test="$isFollowingImage = 'no'"> <xsl:call-template name="create-paragraph"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix" select="$footnotePrefix" /> </xsl:call-template> </xsl:if> </xsl:when> <xsl:when test="draw:frame and ((normalize-space($childText) != '') or (((count(*) - count(text:soft-page-break)) > 1)))"> <!-- If there is a 'draw:frame' child with text (not being whitespace alone) and more than the draw:frame alone and not the draw:frame and a soft-page-break alone (which is quite often) --> <!-- If there is a frame within the text:p or draw:page, its siblings are surrounded as well by a div and are floating (CSS float) --> <!-- But it makes no sense to create floating if the frame is alone or only together with a soft-page-break not usable for HTML --> <!-- The paragraph is written as DIV as there might be nested paragraphs (see above choose block) --> <xsl:choose> <xsl:when test="name() = 'text:p'"> <xsl:comment>Next 'div' was a 'text:p'.</xsl:comment> </xsl:when> <xsl:otherwise> <xsl:comment>Next 'div' was a 'draw:page'.</xsl:comment> </xsl:otherwise> </xsl:choose> <xsl:element name="div"> <xsl:apply-templates select="@*"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <!-- the footnote symbol is the prefix for a footnote in the footer --> <xsl:copy-of select="$footnotePrefix"/> <!-- start floating of frame (and siblings) --> <xsl:apply-templates select="node()[1]" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="previousFrameWidths" select="0"/> <xsl:with-param name="previousFrameHeights" select="0"/> <!-- 2DO for me (Svante) - Not used, uncertain 4now.. <xsl:with-param name="pageMarginLeft"> <xsl:call-template name="getPageMarginLeft"/> </xsl:with-param>--> </xsl:apply-templates> </xsl:element> <!-- after the last draw:frame sibling the CSS float is disabled   is an unbreakable whitespace to give conent to the element and force a browser not to ignore the element --> <div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div> </xsl:when> <xsl:when test="text:tab and not(ancestor::text:index-body)"> <!-- If there is a tabulator (ie. text:tab) within a paragraph, a heuristic for ODF tabulators creates a span for every text:tab embracing the following text nodes aligning them according to the tabulator. A line break or another text:tab starts a new text:span, line break even the tab counter for the line. --> <xsl:element name="p"> <xsl:apply-templates select="@*"> <xsl:with-param name="globalData" select="$globalData" /> </xsl:apply-templates> <!-- start with first child of the paragraph --> <xsl:variable name="firstChildNode" select="node()[1]" /> <xsl:apply-templates select="$firstChildNode" mode="tabHandling"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="tabStops" select="$globalData/all-doc-styles/style[@style:name = current()/@text:style-name]/*/style:tab-stops"/> <xsl:with-param name="parentMarginLeft"> <!-- Styles of first paragraph in list item, including ancestor styles (inheritance) --> <xsl:variable name="paragraphName" select="@text:style-name" /> <xsl:variable name="imageParagraphStyle" select="$globalData/all-styles/style[@style:name = $paragraphName]/final-properties"/> <!-- Only the left margin of the first paragraph of a list item will be added to the margin of the complete list (all levels)--> <!-- 2DO: left-margin in order with bidirectional --> <xsl:choose> <xsl:when test="contains($imageParagraphStyle, 'margin-left:')"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="normalize-space(substring-before(substring-after($imageParagraphStyle, 'margin-left:'), ';'))"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="pageMarginLeft"> <xsl:call-template name="getPageMarginLeft"/> </xsl:with-param> </xsl:apply-templates> </xsl:element> </xsl:when> <xsl:otherwise> <xsl:choose> <!-- !!Check if paragraph is empty!! OOo writes out empty paragraphs layouted behind an image (= draw:image within draw:frame) those have to be neglected in HTML --> <xsl:when test="name() = 'text:p' and not($childText) and not(*)"> <xsl:variable name="isFollowingImage"> <xsl:call-template name="follows-empty-paragraphs-and-image"> <xsl:with-param name="precedingElement" select="preceding-sibling::node()[1]"/> </xsl:call-template> </xsl:variable> <xsl:if test="$isFollowingImage = 'no'"> <xsl:call-template name="create-paragraph"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix" select="$footnotePrefix" /> </xsl:call-template> </xsl:if> </xsl:when> <xsl:otherwise> <xsl:call-template name="create-paragraph"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix" select="$footnotePrefix" /> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- Return the text --> <xsl:template match="text()" mode="getAllTextChildren"> <xsl:value-of select="."/> </xsl:template> <!-- A span will be created for every text:tab embracing the following text nodes. A line break or another text:tab starts a new text:span --> <xsl:template match="* | text()" mode="tabHandling"> <xsl:param name="globalData"/> <xsl:param name="tabStops"/> <!-- there can be multiple tabs in one line, tabNo guesses the one to apply. By default the first i.e. "1" --> <xsl:param name="tabCount" select="0"/> <xsl:param name="parentMarginLeft" /> <xsl:param name="pageMarginLeft" /> <!-- 2DO: EXCHANGE FOLLOING SIBLING BY VARIABLE --> <xsl:variable name="followingSiblingNode" select="following-sibling::node()[1]"/> <!-- Every tabulator indents its following content, encapuslated in a span element. This template have two modes: 1) Before the first tabulator it will match as usually paragraph content to HTML. 2) After the first paragraph it will always triggers two recursions. One embraces the following content of a paragraph element into a span. (tabContentHandling) The other calls this template and will now ignore anything else than TAB and LINE-BREAK. The tabulators and linebreaks are being iterated, one by one to keep track of the tab number --> <xsl:choose> <xsl:when test="name() = 'text:tab'"> <!-- every frame sibling have to be incapuslated within a div with left indent --> <xsl:element name="span"> <xsl:choose> <xsl:when test="count($tabStops/style:tab-stop) > 0 and count($tabStops/style:tab-stop) < 3"> <!-- only allow the heuristic when the style has less than 3 TABS --> <!-- ignore heuristics if no TABS are defined --> <xsl:attribute name="style"> <xsl:call-template name="createTabIndent"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="tabStops" select="$tabStops"/> <xsl:with-param name="tabCount" select="$tabCount + 1"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="pageMarginLeft" select="$pageMarginLeft"/> </xsl:call-template> </xsl:attribute> </xsl:when> <xsl:otherwise> <!-- if there are more than 3 TABS in the style, create a none-breakable-space as whitespace --> <xsl:text> </xsl:text> </xsl:otherwise> </xsl:choose> <xsl:apply-templates select="following-sibling::node()[1]" mode="tabContentHandling"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> <xsl:apply-templates select="following-sibling::node()[1]" mode="tabHandling"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="tabStops" select="$tabStops"/> <xsl:with-param name="tabCount" select="$tabCount + 1"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="pageMarginLeft" select="$pageMarginLeft"/> </xsl:apply-templates> </xsl:when> <xsl:when test="name() = 'text:line-break'"> <!-- A line-break resets the tabCount to '0' --> <br/> <xsl:apply-templates select="following-sibling::node()[1]" mode="tabHandling"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="tabStops" select="$tabStops"/> <xsl:with-param name="tabCount" select="0"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="pageMarginLeft" select="$pageMarginLeft"/> </xsl:apply-templates> </xsl:when> <xsl:otherwise> <!-- only before the first tab all content is written out --> <xsl:if test="$tabCount = 0"> <xsl:apply-templates select="."> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:if> <xsl:apply-templates select="following-sibling::node()[1]" mode="tabHandling"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="tabStops" select="$tabStops"/> <xsl:with-param name="tabCount" select="$tabCount"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="pageMarginLeft" select="$pageMarginLeft"/> </xsl:apply-templates> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- This recursion creates the content of a tab (i.e. following siblings till next TAB or LINE BREAK) and ends with the next TAB, LINE-BREAK or with the end of the paragraph. --> <xsl:template match="* | text()" mode="tabContentHandling"> <xsl:param name="globalData"/> <xsl:if test="(name() != 'text:tab') and (name() != 'text:line-break')"> <!-- Write out content --> <xsl:apply-templates select="."> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <!-- Apply for the next node --> <xsl:apply-templates select="following-sibling::node()[1]" mode="tabContentHandling"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:if> </xsl:template> <xsl:template name="createTabIndent"> <xsl:param name="globalData"/> <xsl:param name="tabStops"/> <xsl:param name="tabCount"/> <xsl:param name="parentMarginLeft" /> <xsl:param name="pageMarginLeft" /> <xsl:text>position:absolute;left:</xsl:text> <xsl:variable name="tabPosition"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$tabStops/style:tab-stop[$tabCount]/@style:position"/> </xsl:call-template> </xsl:variable> <xsl:variable name="tabIndent"> <xsl:choose> <xsl:when test="$tabStops/style:tab-stop[$tabCount]/@style:type = 'center'"> <!-- in case of style:type 'center' the text is even before the tab stop, centered around the beginning. As I see currently no way in mapping this, therefore I do some HEURISTIC (minus -2.5cm) --> <xsl:value-of select="$tabPosition + $parentMarginLeft + $pageMarginLeft - 2.5"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$tabPosition + $parentMarginLeft + $pageMarginLeft"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <!--<xsl:message>TAB: tabCount= <xsl:value-of select="$tabCount"/>, tabPosition= <xsl:value-of select="$tabPosition"/>, tabIndent= <xsl:value-of select="$tabIndent"/> </xsl:message>--> <xsl:choose> <xsl:when test="$tabIndent='NaN'"> <xsl:variable name="tabPositionTmp"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$tabStops/style:tab-stop[last()]/@style:position"/> </xsl:call-template> </xsl:variable> <!-- Heuristic: for every tab that is more than specified give a further 1 cm --> <xsl:value-of select="$parentMarginLeft + $tabPositionTmp + count($tabStops/style:tab-stop) - $tabCount"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$tabIndent"/> </xsl:otherwise> </xsl:choose> <xsl:text>cm;</xsl:text> <xsl:apply-templates select="$tabStops/style:tab-stop[$tabCount]/@style:type"/> </xsl:template> <!-- OOo writes out empty paragraphs layouted behind an image, those have to be neglected in HTML This method checks if an empty paragraph is of that kind! --> <xsl:template name="follows-empty-paragraphs-and-image"> <xsl:param name="precedingElement" /> <xsl:param name="elementToCheck" select="1"/> <xsl:choose> <!-- OOo writes out empty paragraphs layouted behind the image, those have to be neglected in HTML <xsl:when test="name() = 'text:p' and (normalize-space($childText) = '')"> --> <!-- WorkAround: Test if the empty paragraph was added after an image, which OOO often does --> <xsl:when test="(name($precedingElement) = 'text:p' and not($precedingElement/text()) and not($precedingElement/*))"> <xsl:call-template name="follows-empty-paragraphs-and-image"> <xsl:with-param name="precedingElement" select="preceding-sibling::*[$elementToCheck]"/> <xsl:with-param name="elementToCheck" select="$elementToCheck +1"/> </xsl:call-template> </xsl:when> <xsl:when test="$precedingElement/draw:frame">yes</xsl:when> <xsl:otherwise>no</xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="create-paragraph"> <xsl:param name="globalData"/> <!-- the footnote symbol is the prefix for a footnote in the footer --> <xsl:param name="footnotePrefix"/> <!-- xhtml:p may only contain inline elements. If there is one frame beyond, div must be used! --> <xsl:variable name="elementName"> <xsl:choose> <xsl:when test="descendant::draw:frame[1] or descendant::text:p[1]">div</xsl:when> <xsl:otherwise>p</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:element name="{$elementName}"> <xsl:choose> <!-- in ODF borders of paragraphs will be merged by default. Merging means the adjactend paragraphs are building a unit, where only the first and the last will have have a border to the surrounding (top / bottom border) <xsl:variable name="precedingParagraphStyle" select="preceding-sibling::*[1][name() = 'text:p']/@text:style-name"/> <xsl:variable name="followingParagraphStyle" select="following-sibling::*[1][name() = 'text:p']/@text:style-name"/> --> <xsl:when test="$globalData/all-styles/style[@style:name = current()/@text:style-name]/@mergedBorders"> <xsl:variable name="precedingParagraphStyle" select="preceding-sibling::*[1][name() = 'text:p']/@text:style-name"/> <xsl:variable name="followingParagraphStyle" select="following-sibling::*[1][name() = 'text:p']/@text:style-name"/> <xsl:choose> <xsl:when test="$precedingParagraphStyle or $followingParagraphStyle"> <xsl:variable name="isPrecedingBorderParagraph" select="$globalData/all-styles/style[@style:name = $precedingParagraphStyle]/@mergedBorders"/> <xsl:variable name="isFollowingBorderParagraph" select="$globalData/all-styles/style[@style:name = $followingParagraphStyle]/@mergedBorders"/> <xsl:choose> <xsl:when test="not($isPrecedingBorderParagraph) and $isFollowingBorderParagraph"> <xsl:attribute name="class"> <xsl:value-of select="concat(translate(@text:style-name, '.,;: %()[]/\+', '_____________'), '_borderStart')"/> </xsl:attribute> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:when> <xsl:when test="$isPrecedingBorderParagraph and not($isFollowingBorderParagraph)"> <xsl:attribute name="class"> <xsl:value-of select="concat(translate(@text:style-name, '.,;: %()[]/\+', '_____________'), '_borderEnd')"/> </xsl:attribute> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:when> <xsl:otherwise> <xsl:attribute name="class"> <xsl:value-of select="translate(@text:style-name, '.,;: %()[]/\+', '_____________')"/> </xsl:attribute> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise> <xsl:call-template name="write-paragraph"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise> <xsl:call-template name="write-paragraph"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix" select="$footnotePrefix" /> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:element> </xsl:template> <xsl:template name="write-paragraph"> <xsl:param name="globalData"/> <!-- the footnote symbol is the prefix for a footnote in the footer --> <xsl:param name="footnotePrefix" /> <!-- empty paragraph tags does not provoke an carridge return, therefore an non breakable space ( ) have been inserted.--> <xsl:choose> <xsl:when test="node()"> <xsl:call-template name="apply-styles-and-content"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix" select="$footnotePrefix" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:call-template name="apply-styles-and-content"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix" select="$footnotePrefix" /> </xsl:call-template> <xsl:text> </xsl:text> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template match="style:tab-stop/@style:type"> <xsl:text>text-align:</xsl:text> <xsl:choose> <xsl:when test=". = 'left'">left</xsl:when> <xsl:when test=". = 'right'">right</xsl:when> <xsl:when test=". = 'center'">center</xsl:when> <xsl:otherwise>justify</xsl:otherwise> </xsl:choose> <xsl:text>;</xsl:text> </xsl:template> <!-- As soon a frame is within a paragraph (text:p) or page:frame, every child element is floating (CSS) and worked out in sequence. Accumulating prior frame width and adding parent's left margin --> <!-- Matching all elements and text beyond a paragraph/text:page which are sibling of a draw:frame --> <xsl:template match="* | text()" mode="frameFloating"> <xsl:param name="globalData"/> <xsl:param name="previousFrameWidths" select="0"/> <xsl:param name="previousFrameHeights" select="0" /> <!-- it becomes true for siblings after a draw:frame --> <xsl:param name="createDiv" select="false()"/> <xsl:param name="noDivBefore" select="true()"/> <xsl:param name="leftPosition" /> <xsl:param name="parentMarginLeft" /> <xsl:param name="frameAlignedToParagraphWithSvgY" /> <xsl:choose> <xsl:when test="name() = 'draw:frame'"> <xsl:copy-of select="$frameAlignedToParagraphWithSvgY"/> <!-- if the first node is a draw:frame create a div --> <xsl:call-template name="createDrawFrame"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths"/> <xsl:with-param name="previousFrameHeights" select="$previousFrameHeights"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> </xsl:call-template> <!-- next elements will be called after the creation with the new indent (plus width of frame) --> </xsl:when> <xsl:otherwise> <xsl:variable name="nextSiblingIsFrame" select="name(following-sibling::node()[1]) = 'draw:frame'"/> <xsl:choose> <xsl:when test="$createDiv and normalize-space(.) != ''"> <!-- every following frame sibling till the next draw:frame have to be incapuslated within a div with left indent. To be moved alltogether arcording the indent (usually right) --> <xsl:comment>Next 'div' added for floating.</xsl:comment> <xsl:element name="div"> <xsl:attribute name="style"> <xsl:text>position:relative; left:</xsl:text> <xsl:value-of select="$leftPosition"/> <xsl:text>cm;</xsl:text> </xsl:attribute> <xsl:apply-templates select="."> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <!-- if it is a frame sibling it will be NOT incapuslated within the div (as already within one) --> <xsl:if test="not($nextSiblingIsFrame)"> <xsl:apply-templates select="following-sibling::node()[1]" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths"/> <xsl:with-param name="previousFrameHeights" select="$previousFrameHeights"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="createDiv" select="false()"/> <xsl:with-param name="noDivBefore" select="$noDivBefore"/> <xsl:with-param name="frameAlignedToParagraphWithSvgY" select="$frameAlignedToParagraphWithSvgY"/> </xsl:apply-templates> </xsl:if> </xsl:element> <xsl:copy-of select="$frameAlignedToParagraphWithSvgY"/> <!-- Other draw:frame will be created outside of the div element --> <xsl:apply-templates select="following-sibling::draw:frame[1]" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths"/> <xsl:with-param name="previousFrameHeights" select="$previousFrameHeights"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="frameAlignedToParagraphWithSvgY" select="$frameAlignedToParagraphWithSvgY"/> </xsl:apply-templates> </xsl:when> <xsl:when test="not($createDiv)"> <xsl:apply-templates select="."> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="frameAlignedToParagraphWithSvgY" select="$frameAlignedToParagraphWithSvgY"/> </xsl:apply-templates> <xsl:if test="not($nextSiblingIsFrame) or $noDivBefore"> <xsl:apply-templates select="following-sibling::node()[1]" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths"/> <xsl:with-param name="previousFrameHeights" select="$previousFrameHeights"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="createDiv" select="false()"/> <xsl:with-param name="noDivBefore" select="$noDivBefore"/> <xsl:with-param name="frameAlignedToParagraphWithSvgY" select="$frameAlignedToParagraphWithSvgY"/> </xsl:apply-templates> </xsl:if> </xsl:when> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- A XML node other than text or element (e.g. commment) should not stop the recursion --> <xsl:template match="comment()" mode="frameFloating"> <xsl:param name="globalData"/> <xsl:param name="previousFrameWidths" select="0"/> <xsl:param name="previousFrameHeights" select="0" /> <!-- it becomes true for siblings after a draw:frame --> <xsl:param name="createDiv" select="false()"/> <xsl:param name="noDivBefore" select="true()"/> <xsl:param name="leftPosition" /> <xsl:param name="parentMarginLeft" /> <xsl:param name="frameAlignedToParagraphWithSvgY" /> <xsl:apply-templates select="following-sibling::node()[1]" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeft"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="createDiv" select="$createDiv"/> <xsl:with-param name="noDivBefore" select="$noDivBefore"/> </xsl:apply-templates> </xsl:template> <!-- As draw:fame may occure within more elements than in text:p and draw:page --> <xsl:template match="draw:frame"> <xsl:param name="globalData"/> <xsl:param name="previousFrameWidths" select="0"/> <xsl:param name="previousFrameHeights" select="0" /> <xsl:call-template name="createDrawFrame"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths"/> <xsl:with-param name="previousFrameHeights" select="$previousFrameHeights"/> </xsl:call-template> <!-- after the last draw:frame sibling the CSS float is disabled --> <xsl:if test="@text:anchor-type!='as-char'"> <div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div> </xsl:if> </xsl:template> <xsl:template name="getPageMarginLeft"> <!-- approximation to find the correct master page style (with page dimensions) --> <xsl:variable name="masterPageNames"> <!-- Loop over every style:style containing a @style:master-page-name attribute --> <xsl:for-each select="key('masterPage','count')"> <!-- Check if this style is being used in the body --> <xsl:if test="key('elementUsingStyle', ../@style:name)"> <!-- Check every master-page-name if it is not emtpy and return as ';' separated list --> <xsl:if test="string-length(../@style:master-page-name) > 0"> <xsl:value-of select="../@style:master-page-name"/>; </xsl:if> </xsl:if> </xsl:for-each> </xsl:variable> <!-- Take the first of the masterpage list and get the according style:master-page element and find the @style:page-layout-name --> <xsl:variable name="pageLayoutName" select="key('masterPageElements', substring-before($masterPageNames,';'))/@style:page-layout-name"/> <!-- Find the according style:page-layout and store the properties in a variable --> <xsl:variable name="pageMarginLeftAttr" select="key('pageLayoutElements', $pageLayoutName)/style:page-layout-properties/@fo:margin-left"/> <xsl:choose> <xsl:when test="$pageMarginLeftAttr"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$pageMarginLeftAttr"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:template> <!-- Elements and text aside of a draw:frame are floating, here a div is being created. Either for a draw:frame or for text and other elements floating aside --> <xsl:template name="createDrawFrame"> <xsl:param name="globalData"/> <xsl:param name="previousFrameWidths" select="0"/> <xsl:param name="previousFrameHeights" select="0" /> <xsl:param name="parentMarginLeft"/> <xsl:variable name="parentMarginLeftNew"> <xsl:choose> <xsl:when test="string-length(normalize-space($parentMarginLeft)) < 1"> <!-- Styles of first paragraph in list item, including ancestor styles (inheritance) --> <xsl:variable name="paragraphName" select="parent::*/@text:style-name" /> <xsl:variable name="imageParagraphStyle" select="$globalData/all-styles/style[@style:name = $paragraphName]/final-properties"/> <!-- Only the left margin of the first paragraph of a list item will be added to the margin of the complete list (all levels)--> <xsl:choose> <xsl:when test="contains($imageParagraphStyle, 'margin-left:')"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="normalize-space(substring-before(substring-after($imageParagraphStyle, 'margin-left:'), ';'))"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise> <xsl:value-of select="$parentMarginLeft"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:variable name="svgWidth"> <xsl:choose> <xsl:when test="@svg:width"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="@svg:width"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:variable name="svgX"> <xsl:choose> <xsl:when test="@svg:x"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="@svg:x"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:variable name="leftPosition" select="$svgX - $parentMarginLeftNew - $previousFrameWidths"/> <xsl:variable name="svgY"> <xsl:choose> <xsl:when test="@svg:y"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="@svg:y"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:variable> <!-- if the frame is anchored on a paragraph --> <xsl:if test="@text:anchor-type='paragraph'"> <xsl:comment>Next 'div' is emulating the top hight of a draw:frame.</xsl:comment> <!-- When the svg:y is set relativ to the paragraph content, the best way to emulate a positive height, is to add an invisbile division inbetween with a height. Often text will flow into this 'gap', which is handled separately! --> <xsl:if test="$svgY > 0"> <xsl:element name="div"> <xsl:attribute name="style"> <xsl:text>height:</xsl:text> <xsl:value-of select="$svgY"/> <xsl:text>cm;</xsl:text> </xsl:attribute> <xsl:text> </xsl:text> </xsl:element> </xsl:if> </xsl:if> <!-- <xsl:variable name="followingSibling" select="following-sibling::node()[1]"/> <xsl:choose> HEURISTIC: if the frame is anchored on a paragraph and the above gab is big enough to hold a text line, move it behind the text <xsl:when test="@text:anchor-type='paragraph' and ( ($svgY > 0.5) or ($svgX > 4) ) and normalize-space($followingSibling) != ''"> <xsl:apply-templates select="$followingSibling" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths + $svgWidth"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeftNew"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="createDiv" select="true()"/> <xsl:with-param name="noDivBefore" select="false()"/> <xsl:with-param name="frameAlignedToParagraphWithSvgY"> <xsl:call-template name="createDrawFrame2"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths + $svgWidth"/> <xsl:with-param name="parentMarginLeftNew" select="$parentMarginLeftNew"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="svgY" select="$svgY"/> </xsl:call-template> </xsl:with-param> </xsl:apply-templates> </xsl:when> <xsl:otherwise>--> <xsl:call-template name="createDrawFrame2"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths + $svgWidth"/> <xsl:with-param name="parentMarginLeftNew" select="$parentMarginLeftNew"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="svgY" select="$svgY"/> </xsl:call-template> <xsl:apply-templates select="following-sibling::node()[1]" mode="frameFloating"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="previousFrameWidths" select="$previousFrameWidths + $svgWidth"/> <xsl:with-param name="parentMarginLeft" select="$parentMarginLeftNew"/> <xsl:with-param name="leftPosition" select="$leftPosition"/> <xsl:with-param name="createDiv" select="true()"/> <xsl:with-param name="noDivBefore" select="false()"/> </xsl:apply-templates> <!-- </xsl:otherwise> </xsl:choose> --> </xsl:template> <xsl:template name="createDrawFrame2"> <xsl:param name="globalData"/> <xsl:param name="previousFrameWidths" /> <xsl:param name="parentMarginLeftNew"/> <xsl:param name="leftPosition" /> <xsl:param name="svgY" /> <xsl:variable name="elem-name"> <xsl:choose> <xsl:when test="@text:anchor-type='as-char'">span</xsl:when> <xsl:otherwise>div</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:comment>Next ' <xsl:value-of select="$elem-name"/>' is a draw:frame. </xsl:comment> <xsl:element name="{$elem-name}"> <xsl:attribute name="style"> <xsl:call-template name="widthAndHeight"/> <!-- MIB --> <xsl:text> padding:0; </xsl:text> <xsl:if test="@text:anchor-type!='as-char'"> <!-- all images float (CSS float reltaive) with a left position calculated by svg:x - parentMarginLeft - previousFrameWidths --> <xsl:text> float:left; position:relative; left:</xsl:text> <xsl:value-of select="$leftPosition"/> <xsl:text>cm; </xsl:text> <!-- if the frame is anchored on a char --> <xsl:if test="@text:anchor-type='char'"> <xsl:text>top:</xsl:text> <xsl:value-of select="$svgY"/> <xsl:text>cm; </xsl:text> </xsl:if> </xsl:if> </xsl:attribute> <xsl:apply-templates select="@*"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <xsl:apply-templates select="node()"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> </xsl:template> <xsl:template match="svg:desc"/> <xsl:template name="widthAndHeight"> <xsl:if test="@svg:height | @svg:width"> <xsl:choose> <xsl:when test="not(@svg:width)"> <xsl:call-template name="svg:height"/> </xsl:when> <xsl:when test="not(@svg:height)"> <xsl:call-template name="svg:width"/> </xsl:when> <xsl:otherwise> <xsl:call-template name="svg:height"/> <xsl:call-template name="svg:width"/> </xsl:otherwise> </xsl:choose> </xsl:if> </xsl:template> <!-- ***************** --> <!-- *** Text Span *** --> <!-- ***************** --> <xsl:template match="text:span"> <xsl:param name="globalData"/> <xsl:choose> <xsl:when test="draw:frame"> <!-- sometimes an ODF image is anchored as character and the image frame appears within a span (which is not valid for HTML) Heuristic: Neglecting the span assuming no text content aside of frame within span --> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:when> <xsl:otherwise> <xsl:element name="span"> <xsl:call-template name="apply-styles-and-content"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:element> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- **************** --> <!-- *** Headings *** --> <!-- **************** --> <xsl:template match="text:h"> <xsl:param name="globalData"/> <!-- no creation of empty headings (without text content) --> <xsl:if test="text() or descendant::text()"> <!-- The URL linking of an table-of-content is due to a bug (cp. bug id# 102311) not mapped as URL in the XML. Linking of the table-of-content can therefore only be archieved by a work-around in HTML --> <xsl:call-template name="create-heading"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:if> </xsl:template> <!-- default matching for header elements --> <xsl:template name="create-heading"> <xsl:param name="globalData"/> <xsl:variable name="headingLevel"> <xsl:choose> <xsl:when test="@text:outline-level < 6"> <xsl:value-of select="@text:outline-level"/> </xsl:when> <xsl:otherwise>6</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:variable name="headertyp" select="concat('h', $headingLevel)"/> <xsl:element name="{$headertyp}"> <!-- outline style 'text:min-label-width' is interpreted as a CSS 'margin-right' attribute NOTE: Should be handled as CSS style in style header --> <xsl:variable name="min-label" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/*/@text:min-label-width"/> <xsl:attribute name="class"> <xsl:value-of select="translate(@text:style-name, '.,;: %()[]/\+', '_____________')"/> </xsl:attribute> <xsl:call-template name="create-heading-anchor"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> </xsl:template> <xsl:template name="create-heading-anchor"> <xsl:param name="globalData"/> <!-- writing out a heading number if desired.--> <!-- if a corresponding 'text:outline-style' exist or is not empty --> <xsl:choose> <xsl:when test="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/@style:num-format != ''"> <!-- Every heading element will get an unique anchor for its file, from its hiearchy level and name: For example: The heading title 'My favorite heading' might get <a name="1_2_2_My_favorite_heading" /> --> <!-- creating an anchor for referencing the heading (e.g. from content table) --> <xsl:variable name="headingNumber"> <xsl:call-template name="get-heading-number"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:variable> <xsl:call-template name="create-heading-anchor2"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="headingNumber" select="$headingNumber"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:call-template name="create-heading-anchor2"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="get-heading-number"> <xsl:param name="globalData"/> <!-- write number prefix --> <xsl:value-of select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/@style:num-prefix"/> <xsl:call-template name="write-heading-number"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> <!-- write number suffix --> <xsl:value-of select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/@style:num-suffix"/> </xsl:template> <!-- creating an anchor for referencing the heading --> <xsl:template name="create-heading-anchor2"> <xsl:param name="globalData"/> <xsl:param name="headingNumber" /> <xsl:variable name="title"> <xsl:apply-templates mode="concatenate"/> </xsl:variable> <!-- REFERENCE HANDLING - ANCHOR --> <xsl:element namespace="{$namespace}" name="a"> <xsl:attribute name="id"> <xsl:value-of select="translate(concat('a_',$headingNumber, '_', normalize-space($title)), '
&<>.,;: %()[]/\+', '___________________________')"/> </xsl:attribute> <xsl:element name="span"> <!-- outline style 'text:min-label-distance' is interpreted as a CSS 'margin-right' attribute NOTE: Should be handled as CSS style in style header --> <xsl:variable name="minLabelDistance" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/*/@text:min-label-distance"/> <xsl:variable name="minLabelWidth" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/*/@text:min-label-width"/> <xsl:if test="$minLabelDistance | $minLabelWidth"> <xsl:attribute name="style"> <xsl:if test="$minLabelDistance"> <xsl:text>margin-right:</xsl:text> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$minLabelDistance"/> </xsl:call-template> <xsl:text>cm;</xsl:text> </xsl:if> <xsl:if test="$minLabelWidth"> <xsl:text>min-width:</xsl:text> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$minLabelWidth"/> </xsl:call-template> <xsl:text>cm;</xsl:text> </xsl:if> </xsl:attribute> </xsl:if> <xsl:copy-of select="$headingNumber"/> </xsl:element> </xsl:element> </xsl:template> <xsl:template name="write-heading-number"> <xsl:param name="globalData"/> <!-- By default heading start with '1', the parameter 'textStartValue' will only be set, if the attribute @text:start-value exist --> <xsl:choose> <xsl:when test="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/@text:start-value"> <xsl:call-template name="calc-heading-number"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="outlineLevel" select="@text:outline-level"/> <xsl:with-param name="textStartValue" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = current()/@text:outline-level]/@text:start-value"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:call-template name="calc-heading-number"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="outlineLevel" select="@text:outline-level"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- Find the correct heading no., which is the sum of 'text:start-value' and preceding siblings of 'text:h' with the same 'text:outline-level' (until a text:outline-level with lower value is found). If the 'text:start-value is not set the default value of '1' has to be taken. If a heading number is found (e.g. text:outline-level='3') all heading numbers for the higher levels have to be written out --> <xsl:template name="calc-heading-number"> <xsl:param name="globalData"/> <xsl:param name="outlineLevel"/><!-- text level of the heading --> <xsl:param name="iOutlineLevel" select="1"/><!-- iterator, counts from 1 to the text level of the heading --> <xsl:param name="textStartValue" select="1"/><!-- text level to start with, default is '1' --> <xsl:choose> <!-- iText levels counts up from '1' to outlineLevel Which means writing a heading number from left to right --> <xsl:when test="$iOutlineLevel < $outlineLevel"> <!-- Write preceding heading numbers --> <xsl:call-template name="writeNumber"> <xsl:with-param name="numberDigit"> <xsl:call-template name="calc-heading-digit"> <xsl:with-param name="value" select="0"/> <xsl:with-param name="currentoutlineLevel" select="$iOutlineLevel"/> </xsl:call-template> </xsl:with-param> <xsl:with-param name="numberFormat" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = ($outlineLevel)]/@style:num-format"/> </xsl:call-template> <xsl:choose> <xsl:when test="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = ($iOutlineLevel + 1)]/@text:start-value"> <xsl:call-template name="calc-heading-number"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="outlineLevel" select="$outlineLevel"/> <xsl:with-param name="iOutlineLevel" select="$iOutlineLevel + 1"/> <xsl:with-param name="textStartValue" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = ($iOutlineLevel + 1)]/@text:start-value"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:call-template name="calc-heading-number"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="outlineLevel" select="$outlineLevel"/> <xsl:with-param name="iOutlineLevel" select="$iOutlineLevel + 1"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise> <!-- Write preceding heading numbers --> <xsl:call-template name="writeNumber"> <xsl:with-param name="numberDigit"> <xsl:call-template name="calc-heading-digit"> <xsl:with-param name="value" select="$textStartValue"/> <xsl:with-param name="currentoutlineLevel" select="$iOutlineLevel"/> </xsl:call-template> </xsl:with-param> <xsl:with-param name="numberFormat" select="$globalData/office:styles/text:outline-style/text:outline-level-style[@text:level = $outlineLevel]/@style:num-format"/> <xsl:with-param name="last" select="true()"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="writeNumber"> <xsl:param name="numberDigit"/> <xsl:param name="numberFormat"/> <xsl:param name="last"/> <xsl:choose> <xsl:when test="not($numberFormat)"> <xsl:number value="$numberDigit" format="1."/> </xsl:when> <xsl:otherwise> <xsl:choose> <xsl:when test="$last"> <xsl:number value="$numberDigit" format="{$numberFormat}"/> </xsl:when> <xsl:otherwise> <xsl:number value="$numberDigit" format="{$numberFormat}."/> </xsl:otherwise> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="calc-heading-digit"> <xsl:param name="value"/> <xsl:param name="currentoutlineLevel"/> <xsl:param name="i" select="1"/> <xsl:variable name="precedingoutlineLevel" select="preceding-sibling::text:h[$i]/@text:outline-level"/> <xsl:choose> <xsl:when test="$currentoutlineLevel = $precedingoutlineLevel"> <xsl:call-template name="calc-heading-digit"> <xsl:with-param name="value" select="$value + 1"/> <xsl:with-param name="currentoutlineLevel" select="$currentoutlineLevel"/> <xsl:with-param name="i" select="$i + 1"/> </xsl:call-template> </xsl:when> <xsl:when test="$currentoutlineLevel < $precedingoutlineLevel"> <xsl:call-template name="calc-heading-digit"> <xsl:with-param name="value" select="$value"/> <xsl:with-param name="currentoutlineLevel" select="$currentoutlineLevel"/> <xsl:with-param name="i" select="$i + 1"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:value-of select="$value"/> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- Neglect Annotations --> <xsl:template match="office:annotation" mode="concatenate"/> <!-- Match text:placeholder child nodes (e.g. text) --> <xsl:template match="text:placeholder"> <xsl:param name="globalData"/> <xsl:call-template name="apply-styles-and-content"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:template> <!-- ************* --> <!-- *** Link *** --> <!-- ************* --> <xsl:template match="text:a | draw:a"> <xsl:param name="globalData"/> <xsl:call-template name="create-common-anchor-link"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:template> <xsl:template name="create-common-anchor-link"> <xsl:param name="globalData"/> <xsl:element name="a"> <xsl:attribute name="href"> <xsl:call-template name="create-href"> <xsl:with-param name="href" select="@xlink:href"/> </xsl:call-template> </xsl:attribute> <xsl:call-template name="apply-styles-and-content"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:element> </xsl:template> <!-- ******************* --> <!-- *** Image Link *** --> <!-- ******************* --> <!-- currently suggesting that all draw:object-ole elements are images --> <xsl:template match="draw:image | draw:object-ole"> <xsl:param name="globalData"/> <xsl:choose> <xsl:when test="ancestor::text:p or parent::text:span or parent::text:h or parent::draw:a or parent::text:a or text:ruby-base"> <!-- XHTML does not allow the mapped elements to contain paragraphs --> <xsl:call-template name="create-image-element"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <!-- images are embedded in a paragraph, but are in CSS not able to express a horizontal alignment for themself. A 'div' element taking over the image style would solve that problem, but is invalid as child of a paragraph --> <xsl:element name="p"> <xsl:apply-templates select="@draw:style-name"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> <xsl:call-template name="create-image-element"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:element> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="create-image-element"> <xsl:param name="globalData"/> <xsl:element name="img"> <xsl:if test="../@svg:width or ../@svg:height"> <xsl:attribute name="style"> <xsl:if test="../@svg:height"> <xsl:text>height:</xsl:text> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="../@svg:height"/> </xsl:call-template> <xsl:text>cm;</xsl:text> </xsl:if> <xsl:if test="../@svg:width"> <xsl:text>width:</xsl:text> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="../@svg:width"/> </xsl:call-template> <xsl:text>cm;</xsl:text> </xsl:if> </xsl:attribute> </xsl:if> <xsl:attribute name="alt"> <xsl:choose> <xsl:when test="../svg:desc"> <xsl:value-of select="../svg:desc"/> </xsl:when> <xsl:otherwise> <xsl:message> Accessibility Warning: No alternate text ('svg:desc' element) set for image ' <xsl:value-of select="@xlink:href"/>'! </xsl:message> </xsl:otherwise> </xsl:choose> </xsl:attribute> <xsl:attribute name="src"> <xsl:call-template name="create-href"> <xsl:with-param name="href" select="@xlink:href"/> </xsl:call-template> </xsl:attribute> <!-- style interpretation only, as no subelements are allowed for img in XHTML --> <xsl:apply-templates select="@draw:style-name"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:apply-templates> </xsl:element> </xsl:template> <!-- ************ --> <!-- *** list *** --> <!-- ************ --> <!-- Due to the requirements below the ODF list functionality is not handled by CSS, but the list labels calculated and written by XSLT. REQUIREMENTS: ============= A) One significant difference between XHTML and Office List elements is that a list without text nodes but only further list children would not show a list symbol in the Office, but in the browser from XHTML. B) Since OASIS Open Document XML (implemented in OOo2.0) only one parent type exists for list items the 'text:list' element. The XHTML element 'ol', 'ul' will be choosen upon the list style type. C) An Office list may be spread over the whole document. Linked by their style and text:continue-numbering='true'. D) An Office list can use characters or images as list label. E) An Office list can have a prefix and suffix around the list label. F) An Office list style may have the attribute consecutive numbering, which resolves in a list counting for all levels G) An Office list may (re)start on any arbitrary value by using @text:start-value on the text:list-item INDENDATION: ============ The indent of a list label is not only calculated by using the text:space-before of the list level (listLevelStyle), but as well taking the left margin of the first paragraph (or heading) of the list into account as loy match="" name="" use=""/>ng it is not negative. | MARGIN LEFT | LABEL | | text:space-before (listlevelstyle) | text:min-label-width | | + fo:left-margin (firstParagraph) | | Further details beyond text:list-list.. --> <xsl:key name="listStyles" match=" /*/office:styles/text:list-style | /*/office:automatic-styles/text:list-style | /*/office:styles/style:graphic-properties/text:list-style | /*/office:automatic-styles/style:graphic-properties/text:list-style | /*/office:styles/text:list-style | /*/office:automatic-styles/text:list-style | /*/office:styles/style:graphic-properties/text:list-style | /*/office:automatic-styles/style:graphic-properties/text:list-style" use="@style:name"/> <!-- A text list may only have text:list-item and text:list-header as children. --> <xsl:template match="text:list"> <xsl:param name="globalData"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="listLevel" select="1"/> <xsl:param name="listRestart" select="false()"/> <xsl:param name="itemLabel" select="''"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName" select="@text:style-name"/> <!-- To choose list type - get the list style, with the same 'text:style-name' and same 'text:level' >--> <xsl:variable name="listStyleRTF"> <xsl:variable name="listStyleInContentFile" select="key('listStyles', $listStyleName)"/> <xsl:choose> <xsl:when test="$listStyleInContentFile"> <xsl:copy-of select="$listStyleInContentFile"/> </xsl:when> <xsl:when test="$globalData/office:styles/text:list-style[@style:name = $listStyleName]"> <xsl:copy-of select="$globalData/office:styles/text:list-style[@style:name = $listStyleName]"/> </xsl:when> <xsl:when test="$globalData/office:styles/style:graphic-properties/text:list-style[@style:name = $listStyleName]"> <xsl:copy-of select="$globalData/office:styles/style:graphic-properties/text:list-style[@style:name = $listStyleName]"/> </xsl:when> </xsl:choose> </xsl:variable> <xsl:choose> <xsl:when test="function-available('common:node-set')"> <xsl:call-template name="create-list-type"> <xsl:with-param name="listStyle" select="common:node-set($listStyleRTF)" /> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listStyleName" select="$listStyleName" /> </xsl:call-template> </xsl:when> <xsl:when test="function-available('xalan:nodeset')"> <xsl:call-template name="create-list-type"> <xsl:with-param name="listStyle" select="xalan:nodeset($listStyleRTF)" /> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listStyleName" select="$listStyleName" /> </xsl:call-template> </xsl:when> <xsl:when test="function-available('xt:node-set')"> <xsl:call-template name="create-list-type"> <xsl:with-param name="listStyle" select="xt:node-set($listStyleRTF)" /> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listStyleName" select="$listStyleName" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:message terminate="yes">The required node-set function was not found!</xsl:message> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="create-list-type"> <xsl:param name="globalData"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="listLevel" /> <xsl:param name="listRestart" /> <xsl:param name="itemLabel"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName" /> <!-- $globalData/styles-file/*/office:styles/ --> <xsl:variable name="listLevelStyle" select="$listStyle/*/*[@text:level = number($listLevel)]"/> <xsl:variable name="listIndent"> <xsl:call-template name="getListIndent"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="firstPara" select="*[1]/*[name() = 'text:p' or name() = 'text:h'][1]"/> </xsl:call-template> </xsl:variable> <xsl:variable name="isEmptyList" select="not(*[1]/*[name() = 'text:h' or name() = 'text:p' or name() = 'text:name'])"/> <xsl:variable name="listType"> <xsl:choose> <!-- ordered list --> <xsl:when test="name($listLevelStyle) = 'text:list-level-style-number'"> <xsl:text>ol</xsl:text> </xsl:when> <!-- unordered list (bullet or image) --> <xsl:otherwise> <xsl:text>ul</xsl:text> </xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:element name="{$listType}"> <xsl:apply-templates select="*[1]" mode="listItemSibling"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset"> <xsl:choose> <xsl:when test="$isListNumberingReset"> <xsl:value-of select="true()"/> </xsl:when> <xsl:otherwise> <!-- A list is empty if a text:list does not have a text:list-header or text:list-item (wildcard as only those can exist beyond a text:list), which contains a text:h or text:p --> <xsl:value-of select="not($isEmptyList)"/> </xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listRestart"> <xsl:choose> <xsl:when test="$listRestart"> <xsl:value-of select="$listRestart"/> </xsl:when> <xsl:otherwise> <!-- descdendants restart their list numbering, when an ancestor is not empty --> <xsl:value-of select="not($isEmptyList)"/> </xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="minLabelDist"> <xsl:choose> <xsl:when test="$listLevelStyle/*/@text:min-label-distance"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$listLevelStyle/*/@text:min-label-distance"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="minLabelWidth"> <xsl:choose> <xsl:when test="$listLevelStyle/*/@text:min-label-width"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$listLevelStyle/*/@text:min-label-width"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:with-param> </xsl:apply-templates> </xsl:element> </xsl:template> <!-- See comment before text:list template --> <xsl:template name="getListIndent"> <xsl:param name="globalData"/> <xsl:param name="listLevelStyle"/> <!-- The first paragraph of the list item (heading is special paragraph in ODF) --> <xsl:param name="firstPara" /> <!-- Styles of first paragraph in list item, including ancestor styles (inheritance) --> <xsl:variable name="firstParaStyles" select="$globalData/all-styles/style[@style:name = $firstPara/@text:style-name]/final-properties"/> <!-- Only the left margin of the first paragraph of a list item will be added to the margin of the complete list (all levels)--> <xsl:variable name="firstParaLeftMargin"> <xsl:choose> <xsl:when test="contains($firstParaStyles, 'margin-left:')"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="normalize-space(substring-before(substring-after($firstParaStyles, 'margin-left:'), ';'))"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:variable name="spaceBefore"> <xsl:choose> <xsl:when test="$listLevelStyle/*/@text:space-before"> <xsl:call-template name="convert2cm"> <xsl:with-param name="value" select="$listLevelStyle/*/@text:space-before"/> </xsl:call-template> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:variable> <!-- Only if the left-margin of the first paragraph is positive the sum text:space-before and fo:left-margin is taken as list indent --> <xsl:choose> <xsl:when test="$firstParaLeftMargin > 0"> <xsl:value-of select="$firstParaLeftMargin + $spaceBefore"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$spaceBefore"/> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- ****************** --> <!-- *** list item *** --> <!-- ****************** --> <!-- Left margin of the complete list: The space between left page and the list symbol (left-margin) is in the Office implemented by the sum of three values: 1) 'text:space-before', which is part of the 'text:list-style' element. 2) 'margin:left' from the style of the first child (e.g. paragraph). 3) 'fo:text-indent' the indent of the first line of some child (e.g. paragraph) (applied by CSS class style) Possible list children: <!ELEMENT text:list-item (text:p|text:h|text:list|text:list)+> In the Office the list label before the text depends on two attributes: - 'text:min-label-width': the distance between list label and all text of the list item. - 'text:min-label-distance': the distance between list label and text of the first line, only used, when text does not fit in text:min-label-width (ignored) --> <xsl:template match="text:list-item | text:list-header" mode="listItemSibling"> <xsl:param name="globalData"/> <xsl:param name="firstitemLabelWidth"/> <xsl:param name="isEmptyList" select="not(*[name() = 'text:h' or name() = 'text:p' or name() = 'text:name'])"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="itemNumber"/> <xsl:param name="itemLabel"/> <xsl:param name="listLevel"/> <xsl:param name="listLevelStyle"/> <xsl:param name="listRestart"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="minLabelDist"/> <xsl:param name="minLabelWidth"/> <xsl:param name="listIndent" /> <!-- The text:list-header shall not be labeled. According to ODF specification (sect. 4.3.2): "The <text:list-header> element represents a list header and is a special kind of list item. It contains one or more paragraphs that are displayed before a list. The paragraphs are formatted like list items but they do not have a preceding number or bullet." --> <xsl:variable name="isListHeader" select="boolean(self::text:list-header)"/> <xsl:variable name="listIndentNew"> <xsl:choose> <xsl:when test="$listIndent"> <xsl:value-of select="$listIndent"/> </xsl:when> <xsl:otherwise> <xsl:call-template name="getListIndent"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="firstPara" select="*[name() = 'text:p' or name() = 'text:h'][1]" /> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:variable name="itemNumberNew"> <xsl:if test="$listStyle/text:list-style/text:list-level-style-number"> <xsl:choose> <xsl:when test="$isListHeader">0</xsl:when> <xsl:when test="$isEmptyList"> <!-- An empty list item (no text:h/text:p as child), will not count as item and does not increment the count. --> <xsl:variable name="tempItemNumber"> <xsl:choose> <!-- siblings will be incremented by one --> <xsl:when test="$itemNumber"> <xsl:if test="not($isListHeader)"> <xsl:value-of select="$itemNumber + 1"/> </xsl:if> </xsl:when> <!-- if a higher list level had content the numbering starts with 1 --> <xsl:when test="$isListNumberingReset and $listLevel > 1"> <xsl:value-of select="1"/> </xsl:when> <xsl:otherwise> <xsl:call-template name="getItemNumber"> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:choose> <!-- in case the empty list-item is the first list-item in document --> <xsl:when test="$tempItemNumber = 1"> <xsl:value-of select="1"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$tempItemNumber - 1"/> </xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise> <xsl:choose> <xsl:when test="@text:start-value"> <xsl:value-of select="@text:start-value"/> </xsl:when> <!-- text:start-value from list level style will only be taken on the first list-item of a list --> <xsl:when test="$listLevelStyle/@text:start-value and count(preceding-sibling::text:list-item) = 0"> <xsl:value-of select="$listLevelStyle/@text:start-value"/> </xsl:when> <!-- siblings will be incremented by one --> <xsl:when test="$itemNumber"> <xsl:value-of select="$itemNumber + 1"/> </xsl:when> <!-- if a higher list level had content the numbering starts with 1 --> <xsl:when test="$isListNumberingReset and $listLevel > 1"> <xsl:value-of select="1"/> </xsl:when> <xsl:otherwise> <xsl:call-template name="getItemNumber"> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:if> </xsl:variable> <xsl:variable name="itemLabelNew"> <xsl:if test="$listStyle/text:list-style/text:list-level-style-number"> <!-- A numbered label (e.g. 2.C.III) is created for every text:list-item/header. Above list levels are listed in the label, if the list-style requires this. Levels are separated by a '.' Formatation is dependent for every list level depth. The label is passed from anchestor text:list-item/header and if requrired truncated. The prefix/suffix (as well list level dependent) comes before and after the complete label (after truncation) --> <!-- Numbered label will be generated --> <xsl:call-template name="createItemLabel"> <xsl:with-param name="itemNumber" select="$itemNumberNew"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listLevelsToDisplay"> <xsl:variable name="display" select="$listLevelStyle/@text:display-levels"/> <xsl:choose> <xsl:when test="$display"> <xsl:value-of select="$display"/> </xsl:when> <xsl:when test="$isListHeader">0</xsl:when> <xsl:otherwise>1</xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> </xsl:call-template> </xsl:if> </xsl:variable> <xsl:element name="li"> <xsl:choose> <xsl:when test="$isEmptyList or $isListHeader"> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="itemLabel" select="$itemLabelNew"/> <xsl:with-param name="listLevel" select="$listLevel + 1"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> </xsl:apply-templates> </xsl:when> <xsl:otherwise> <!-- Possible following children are text:h, text:p, list:text, text:soft-page-break --> <xsl:apply-templates mode="list-item-children" select="*[1]"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isListHeader or $isNextLevelNumberingReset"/> <!-- The new created label is given to the children --> <xsl:with-param name="itemLabel" select="$itemLabelNew"/> <xsl:with-param name="listLabelElement"> <xsl:choose> <xsl:when test="name() = 'text:list-header'"/> <xsl:otherwise> <xsl:variable name="listLabelWidth"> <xsl:choose> <xsl:when test="$minLabelWidth > $minLabelDist"> <xsl:value-of select="$minLabelWidth"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$minLabelDist"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <!-- Numbering is being done by this transformation creating a HTML span representing the number label The html:span represents the list item/header label (e.g. 1.A.III) As the html:span is usually a inline element is formated by CSS as block element to use width upon it, to disable the caridge return float:left is used and later neglected --> <xsl:element name="span"> <xsl:if test="$listLevelStyle/@text:style-name"> <xsl:attribute name="class"> <xsl:value-of select="$listLevelStyle/@text:style-name"/> </xsl:attribute> </xsl:if> <xsl:attribute name="style"> <xsl:text>display:block;float:</xsl:text> <!-- 2DO: Svante - copy this functionality for other used margin:left (in western country 'left') --> <xsl:call-template name="getOppositeWritingDirection"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="paraStyleName" select="descendant-or-self::*/@text:style-name"/> </xsl:call-template> <xsl:text>;min-width:</xsl:text> <xsl:value-of select="$listLabelWidth"/> <xsl:text>cm</xsl:text> </xsl:attribute> <xsl:variable name="labelContent"> <xsl:choose> <xsl:when test="text:number"> <xsl:apply-templates select="text:number" mode="listnumber"/> </xsl:when> <xsl:when test="name($listLevelStyle) = 'text:list-level-style-bullet'"> <xsl:value-of select="$listLevelStyle/@style:num-prefix"/> <xsl:value-of select="$listLevelStyle/@text:bullet-char"/> <xsl:value-of select="$listLevelStyle/@style:num-suffix"/> </xsl:when> <xsl:when test="name($listLevelStyle) = 'text:list-level-style-number'"> <xsl:value-of select="$listLevelStyle/@style:num-prefix"/> <xsl:value-of select="$itemLabelNew"/> <xsl:value-of select="$listLevelStyle/@style:num-suffix"/> </xsl:when> <xsl:otherwise> <!-- Listing with image as bullets, taken from the list style's href --> <xsl:value-of select="$listLevelStyle/@xlink:href"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <!-- Some browsers have problem with stand-alone elements (e.g. <span/>) Therefore a comment is being inserted into an empty label --> <xsl:choose> <xsl:when test="$labelContent != ''"> <xsl:value-of select="$labelContent"/> </xsl:when> <xsl:otherwise> <xsl:comment> </xsl:comment> </xsl:otherwise> </xsl:choose> </xsl:element> </xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="listLabelEmptyElement"> <xsl:variable name="listLabelWidth"> <xsl:choose> <xsl:when test="$minLabelWidth > $minLabelDist"> <xsl:value-of select="$minLabelWidth"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$minLabelDist"/> </xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:element name="span"> <xsl:if test="$listLevelStyle/@text:style-name"> <xsl:attribute name="class"> <xsl:value-of select="$listLevelStyle/@text:style-name"/> </xsl:attribute> </xsl:if> <xsl:attribute name="style"> <xsl:text>display:block;float:</xsl:text> <xsl:call-template name="getOppositeWritingDirection"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="paraStyleName" select="descendant-or-self::*/@text:style-name"/> </xsl:call-template> <xsl:text>;min-width:</xsl:text> <xsl:value-of select="$listLabelWidth"/> <xsl:text>cm</xsl:text> </xsl:attribute> <xsl:comment> </xsl:comment> </xsl:element> </xsl:with-param> <xsl:with-param name="listLevel" select="$listLevel + 1"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listIndent" select="$listIndentNew"/> <xsl:with-param name="minLabelWidth" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:otherwise> </xsl:choose> </xsl:element> <xsl:apply-templates select="following-sibling::*[1]" mode="listItemSibling"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemNumber" select="$itemNumberNew"/> <xsl:with-param name="listIndent"> <xsl:choose> <xsl:when test="not($isEmptyList)"> <xsl:value-of select="$listIndentNew"/> </xsl:when> </xsl:choose> </xsl:with-param> <!-- Receives the same parent label --> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="minLabelDist" select="$minLabelDist"/> <xsl:with-param name="minLabelWidth" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:template> <xsl:template name="getOppositeWritingDirection"> <xsl:param name="globalData"/> <xsl:param name="paraStyleName"/> <xsl:variable name="imageParagraphStyle" select="$globalData/all-styles/style[@style:name = $paraStyleName]/final-properties"/> <xsl:choose> <xsl:when test="contains($imageParagraphStyle, 'writing-mode:')"> <xsl:choose> <xsl:when test="contains(substring-before(substring-after($imageParagraphStyle, 'writing-mode:'), ';'), 'rl')">right</xsl:when> <xsl:otherwise>left</xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise>left</xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template match="text:number" mode="listnumber"> <xsl:apply-templates/> </xsl:template> <xsl:template match="text:number" mode="list-item-children"> <xsl:param name="globalData"/> <xsl:param name="listLabelElement"/> <xsl:param name="listLabelEmptyElement"/> <xsl:param name="isEmptyList"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="itemLabel"/> <xsl:param name="itemNumber"/> <xsl:param name="listIndent"/> <xsl:param name="listLevel"/> <xsl:param name="listLevelStyle" /> <xsl:param name="listRestart"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="minLabelWidth"/> <xsl:apply-templates mode="list-item-children" select="following-sibling::*[1]"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listLabelElement" select="$listLabelElement"/> <xsl:with-param name="listLabelEmptyElement" select="$listLabelEmptyElement"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="minLabelWidth" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:template> <!-- Each key element holds the set of all text:list-item/text:list-header of a certain level and a certain style --> <xsl:key name="getListItemsByLevelAndStyle" use="concat(count(ancestor::text:list), ancestor::text:list/@text:style-name)" match="text:list-item | text:list-header"/> <!-- Each key element holds the set of all text:list-item/text:list-header of a certain style --> <xsl:key name="getListItemsByStyle" use="ancestor::text:list/@text:style-name" match="text:list-item | text:list-header"/> <!-- The Numbering start value (or offset from regular counteing) is used at the first item of offset, but have to be reused on following items with no text:start-value --> <xsl:template name="getItemNumber"> <xsl:param name="listLevel"/> <xsl:param name="listLevelStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="listStyle"/> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="preceding::text:list-item[generate-id(key('getListItemsByLevelAndStyle', concat($listLevel, $listStyleName))) = generate-id(key('getListItemsByLevelAndStyle', concat(count(ancestor::text:list), ancestor::text:list/@text:style-name)))]"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="preceding::text:list-item[generate-id(key('getListItemsByStyle', $listStyleName)) = generate-id(key('getListItemsByStyle', ancestor::text:list/@text:style-name))]"/> </xsl:call-template> </xsl:template> <!-- When there is a text:start-value the last have to be found and added to the number --> <xsl:template name="countListItemTillStartValue"> <xsl:param name="IteratorSameLevelAndStyle" select="1"/> <xsl:param name="IteratorSameStyle" select="1"/> <xsl:param name="itemNumber" select="1"/> <xsl:param name="listLevel"/> <xsl:param name="listLevelStyle"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="precedingListItemsOfSameLevelAndStyle" /> <xsl:param name="precedingListItemsOfSameLevelAndStyleCount" select="count($precedingListItemsOfSameLevelAndStyle)"/> <xsl:param name="precedingListItemsOfSameStyle" /> <xsl:param name="precedingListItemsOfSameStyleCount" select="count($precedingListItemsOfSameStyle)"/> <!-- E.g.: If a list level 2 number is searched, a level 3 with content found with only a level 1 parent with content, the level 3 gets a 'pseudoLevel' --> <xsl:param name="pseudoLevel" select="0" /> <xsl:variable name="isListHeader" select="boolean(self::text:list-header)"/> <xsl:variable name="isEmptyList" select="not(*[name() = 'text:h' or name() = 'text:p'])"/> <!-- set the next of preceding list items. Starting from the current to the next previous text:list-item --> <xsl:variable name="precedingListItemOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle[$precedingListItemsOfSameLevelAndStyleCount - $IteratorSameLevelAndStyle + 1]"/> <xsl:variable name="precedingListItemOfSameStyle" select="$precedingListItemsOfSameStyle[$precedingListItemsOfSameStyleCount - $IteratorSameStyle + 1]"/> <xsl:choose> <xsl:when test="($precedingListItemOfSameStyle and $precedingListItemOfSameLevelAndStyle) or ($precedingListItemOfSameStyle and $listStyle/text:list-style/@text:consecutive-numbering)"> <xsl:for-each select="$precedingListItemOfSameStyle"> <xsl:choose> <!-- if it is a higher list level element --> <xsl:when test="$listStyle/text:list-style/@text:consecutive-numbering"> <xsl:call-template name="countListItem"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="$pseudoLevel" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <!-- NOT CONSECUTIVE NUMBERING --> <xsl:variable name="currentListLevel" select="count(ancestor::text:list)"/> <xsl:choose> <!-- IF IT IS A HIGHER LIST LEVEL ELEMENT --> <xsl:when test="$currentListLevel < $listLevel"> <xsl:choose> <!-- if it has content the counting is ended --> <xsl:when test="*[name() = 'text:h' or name() = 'text:p'] or $isListHeader"> <!-- 2DO: Perhaps the children still have to be processed --> <xsl:value-of select="$itemNumber + $pseudoLevel"/> </xsl:when> <xsl:otherwise> <!-- if it is empty the counting continues --> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle + 1"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="$pseudoLevel" /> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:when> <!-- IF IT IS A LIST LEVEL ELEMENT OF THE COUNTING LEVEL --> <xsl:when test="$currentListLevel = $listLevel"> <xsl:call-template name="countListItem"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="$pseudoLevel" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <!-- list item below the current level does not count --> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle + 1"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel"> <xsl:choose> <!-- empty list item does not count --> <xsl:when test="not(*[name() = 'text:h' or name() = 'text:p']) or $isListHeader"> <xsl:value-of select="$pseudoLevel"/> </xsl:when> <xsl:otherwise>1</xsl:otherwise> </xsl:choose> </xsl:with-param> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:for-each> </xsl:when> <xsl:otherwise> <xsl:value-of select="$itemNumber"/> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="countListItem"> <xsl:param name="IteratorSameLevelAndStyle"/> <xsl:param name="IteratorSameStyle"/> <xsl:param name="itemNumber"/> <xsl:param name="listLevel"/> <xsl:param name="listLevelStyle"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="precedingListItemsOfSameLevelAndStyle"/> <xsl:param name="precedingListItemsOfSameLevelAndStyleCount"/> <xsl:param name="precedingListItemsOfSameStyle"/> <xsl:param name="precedingListItemsOfSameStyleCount"/> <xsl:param name="pseudoLevel" /> <xsl:variable name="isListHeader" select="boolean(self::text:list-header)"/> <xsl:variable name="isEmptyList" select="not(*[name() = 'text:h' or name() = 'text:p'])"/> <xsl:choose> <xsl:when test="@text:start-value"> <xsl:choose> <xsl:when test="$isEmptyList or $isListHeader"> <!-- empty list item does not count. neither does list header --> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle + 1" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle + 1"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="$pseudoLevel" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:value-of select="$itemNumber + @text:start-value"/> </xsl:otherwise> </xsl:choose> </xsl:when> <xsl:when test="$listLevelStyle/@text:start-value"> <xsl:choose> <xsl:when test="$isEmptyList or $isListHeader"> <!-- empty list item does not count. neither does list header --> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle + 1" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle + 1"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="$pseudoLevel" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:value-of select="$itemNumber + $listLevelStyle/@text:start-value"/> </xsl:otherwise> </xsl:choose> </xsl:when> <xsl:otherwise> <xsl:choose> <xsl:when test="$isEmptyList or $isListHeader"> <!-- empty list item does not count. neither does list header --> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle + 1" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle + 1"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="$pseudoLevel" /> </xsl:call-template> </xsl:when> <xsl:otherwise> <!-- count on till you find a start-value or the end is reached --> <xsl:call-template name="countListItemTillStartValue"> <xsl:with-param name="IteratorSameLevelAndStyle" select="$IteratorSameLevelAndStyle + 1" /> <xsl:with-param name="IteratorSameStyle" select="$IteratorSameStyle + 1"/> <xsl:with-param name="itemNumber" select="$itemNumber + 1"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyle" select="$precedingListItemsOfSameLevelAndStyle"/> <xsl:with-param name="precedingListItemsOfSameLevelAndStyleCount" select="$precedingListItemsOfSameLevelAndStyleCount"/> <xsl:with-param name="precedingListItemsOfSameStyle" select="$precedingListItemsOfSameStyle"/> <xsl:with-param name="precedingListItemsOfSameStyleCount" select="$precedingListItemsOfSameStyleCount"/> <xsl:with-param name="pseudoLevel" select="0" /> </xsl:call-template> </xsl:otherwise> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:template> <!-- Creates the list label containing the number, which is separated by '.' between the levels. Depending on the levels to display (listLevelsToDisplay) --> <xsl:template name="createItemLabel"> <xsl:param name="itemLabel" select="''"/> <xsl:param name="itemNumber" /> <xsl:param name="listLevel" /> <xsl:param name="listLevelStyle" /> <xsl:param name="listLevelsToDisplay" /> <xsl:choose> <xsl:when test="$listLevelsToDisplay < $listLevel"> <xsl:call-template name="truncLabel"> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="itemNumber" select="$itemNumber" /> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle" /> <xsl:with-param name="listLevelsToDisplay" select="$listLevelsToDisplay"/> </xsl:call-template> </xsl:when> <xsl:otherwise> <xsl:variable name="numberedSymbol"> <xsl:comment> </xsl:comment> <!-- only give out a number when number format is not empty --> <xsl:if test="$listLevelStyle/@style:num-format != ''"> <xsl:number value="$itemNumber" format="{$listLevelStyle/@style:num-format}"/> </xsl:if> </xsl:variable> <xsl:choose> <xsl:when test="$listLevelsToDisplay != 1"> <xsl:value-of select="concat($itemLabel, '.' , $numberedSymbol)"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$numberedSymbol"/> </xsl:otherwise> </xsl:choose> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template name="truncLabel"> <xsl:param name="itemLabel" /> <xsl:param name="itemNumber" /> <xsl:param name="listLevel" /> <xsl:param name="listLevelStyle" /> <xsl:param name="listLevelsToDisplay" /> <xsl:param name="listStyle" /> <xsl:param name="listStyleName" /> <xsl:call-template name="createItemLabel"> <xsl:with-param name="itemLabel"> <xsl:if test="contains($itemLabel, '.')"> <xsl:value-of select="substring-after($itemLabel, '.')"/> </xsl:if> </xsl:with-param> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLevel" select="$listLevel - 1"/> <xsl:with-param name="listLevelStyle" select="$listLevelStyle"/> <xsl:with-param name="listLevelsToDisplay" select="$listLevelsToDisplay"/> </xsl:call-template> </xsl:template> <xsl:template match="text:p" mode="list-item-children"> <xsl:param name="globalData"/> <xsl:param name="listLabelElement"/> <xsl:param name="listLabelEmptyElement"/> <xsl:param name="isEmptyList"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="itemLabel"/> <xsl:param name="itemNumber"/> <xsl:param name="listIndent"/> <xsl:param name="listLevel"/> <xsl:param name="listRestart"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="minLabelWidth"/> <!-- 2DO page alignment fix - PART1 --> <!-- xhtml:p may only contain inline elements. If there is one frame beyond, div must be used! --> <xsl:variable name="elementName"> <xsl:choose> <xsl:when test="descendant::draw:frame[1] or descendant::text:p[1]">div</xsl:when> <xsl:otherwise>p</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:element name="{$elementName}"> <xsl:call-template name="create-list-style"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="styleName" select="@text:style-name"/> </xsl:call-template> <xsl:choose> <xsl:when test="$listLabelElement"> <xsl:copy-of select="$listLabelElement"/> </xsl:when> <xsl:otherwise> <xsl:copy-of select="$listLabelEmptyElement"/> </xsl:otherwise> </xsl:choose> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="listIndent" select="$minLabelWidth"/> </xsl:apply-templates> <!-- this span disables the float necessary to bring two block elements on one line. It contains a space as IE6 bug workaround --> <span class="odfLiEnd"></span> <xsl:text> </xsl:text> </xsl:element> <xsl:apply-templates mode="list-item-children" select="following-sibling::*[1]"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLabelEmptyElement" select="$listLabelEmptyElement"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="minLabelWidth" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:template> <!-- Neglecting the left margin behavior for headings for now --> <xsl:template match="text:h" mode="list-item-children"> <xsl:param name="globalData"/> <xsl:param name="listLabelElement"/> <xsl:param name="listLabelEmptyElement"/> <xsl:param name="isEmptyList"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="itemLabel"/> <xsl:param name="itemNumber"/> <xsl:param name="listIndent"/> <xsl:param name="listLevel"/> <xsl:param name="listRestart"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="minLabelWidth"/> <xsl:element name="h"> <xsl:call-template name="create-list-style"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="styleName" select="@text:style-name"/> </xsl:call-template> <xsl:variable name="title"> <xsl:apply-templates mode="concatenate"/> </xsl:variable> <xsl:choose> <xsl:when test="$listLabelElement"> <xsl:copy-of select="$listLabelElement"/> </xsl:when> <xsl:otherwise> <xsl:copy-of select="$listLabelEmptyElement"/> </xsl:otherwise> </xsl:choose> <!-- REFERENCE HANDLING - ANCHOR --> <xsl:element namespace="{$namespace}" name="a"> <xsl:attribute name="id"> <xsl:value-of select="translate(concat('a_',$listLabelElement, '_', normalize-space($title)), '
&<>.,;: %()[]/\+', '___________________________')"/> </xsl:attribute> <xsl:apply-templates> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="listIndent" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:element> <!-- this span disables the float necessary to bring two block elements on one line. It contains a space as IE6 bug workaround --> <span class="odfLiEnd"></span> <xsl:text> </xsl:text> </xsl:element> <xsl:apply-templates mode="list-item-children" select="following-sibling::*[1]"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLabelEmptyElement" select="$listLabelEmptyElement"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="minLabelWidth" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:template> <xsl:template match="*" mode="list-item-children"> <xsl:param name="globalData"/> <xsl:param name="isEmptyList"/> <xsl:param name="listLabelEmptyElement"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="itemLabel"/> <xsl:param name="itemNumber"/> <xsl:param name="listIndent"/> <xsl:param name="listLevel"/> <xsl:param name="listRestart"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:param name="minLabelWidth"/> <xsl:apply-templates select="self::*"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="listLabelEmptyElement" select="$listLabelEmptyElement"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> </xsl:apply-templates> <xsl:apply-templates mode="list-item-children" select="following-sibling::*[1]"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listLabelEmptyElement" select="$listLabelEmptyElement"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listRestart" select="$listRestart"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> <xsl:with-param name="listIndent" select="$listIndent"/> <xsl:with-param name="minLabelWidth" select="$minLabelWidth"/> </xsl:apply-templates> </xsl:template> <xsl:template match="*" mode="listItemSibling"> <xsl:param name="globalData"/> <xsl:param name="isEmptyList"/> <xsl:param name="isListNumberingReset"/> <xsl:param name="isNextLevelNumberingReset"/> <xsl:param name="itemLabel"/> <xsl:param name="itemNumber"/> <xsl:param name="listIndent"/> <xsl:param name="listLevel"/> <xsl:param name="listRestart"/> <xsl:param name="listStyle"/> <xsl:param name="listStyleName"/> <xsl:apply-templates select="self::*"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listIndent" select="$listIndent"/> <!-- receives the same parent label, only with a different itemNumber --> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> </xsl:apply-templates> <xsl:apply-templates select="following-sibling::*[1]" mode="listItemSibling"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="isEmptyList" select="$isEmptyList"/> <xsl:with-param name="isListNumberingReset" select="$isListNumberingReset"/> <xsl:with-param name="isNextLevelNumberingReset" select="$isNextLevelNumberingReset"/> <xsl:with-param name="itemNumber" select="$itemNumber"/> <xsl:with-param name="listIndent" select="$listIndent"/> <!-- receives the same parent label, only with a different itemNumber --> <xsl:with-param name="itemLabel" select="$itemLabel"/> <xsl:with-param name="listLevel" select="$listLevel"/> <xsl:with-param name="listStyle" select="$listStyle"/> <xsl:with-param name="listStyleName" select="$listStyleName"/> </xsl:apply-templates> </xsl:template> <xsl:template match="text()" mode="list-item-children"> <xsl:value-of select="."/> </xsl:template> <xsl:template name="create-list-style"> <xsl:param name="globalData"/> <xsl:param name="listIndent" select="0"/> <xsl:param name="styleName"/> <xsl:if test="$styleName"> <xsl:attribute name="class"> <xsl:value-of select="translate($styleName, '.,;: %()[]/\+', '_____________')"/> </xsl:attribute> </xsl:if> <xsl:attribute name="style"> <xsl:text>margin-</xsl:text> <xsl:call-template name="getOppositeWritingDirection"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="paraStyleName" select="descendant-or-self::*/@text:style-name"/> </xsl:call-template> <xsl:text>:</xsl:text> <xsl:value-of select="$listIndent"/> <xsl:text>cm;</xsl:text> </xsl:attribute> </xsl:template> <!-- ********************************************** --> <!-- *** Text Section (contains: draw:text-box) *** --> <!-- ********************************************** --> <xsl:template match="text:section"> <xsl:param name="globalData"/> <xsl:if test="not(contains(@text:display, 'none'))"> <xsl:comment>Next 'div' was a 'text:section'.</xsl:comment> <xsl:element name="div"> <xsl:call-template name="apply-styles-and-content"> <xsl:with-param name="globalData" select="$globalData"/> </xsl:call-template> </xsl:element> </xsl:if> </xsl:template> <!-- Hidden text dependend on Office variables: The text is not shown, if condition is 'true'. Implemented solely for conditons as '<VARIABLE>==0' or '<VARIABLE>==1' --> <xsl:key match="text:variable-set" name="varSet" use="@text:name"/> <xsl:template match="text:hidden-text"> <xsl:param name="globalData"/> <xsl:variable name="varName" select="substring-before(@text:condition, '==')"/> <xsl:variable name="varValue" select="substring-after(@text:condition, '==')"/> <xsl:choose> <xsl:when test="key('varSet', $varName)/@text:value != $varValue"> <xsl:value-of select="@text:string-value"/> </xsl:when> <xsl:otherwise> <xsl:comment> <xsl:value-of select="$varName"/> <xsl:value-of select="@text:string-value"/> <xsl:value-of select="$varName"/> </xsl:comment> </xsl:otherwise> </xsl:choose> </xsl:template> <xsl:template match="@text:style-name | @draw:style-name | @draw:text-style-name | @table:style-name"><!-- | @presentation:style-name--> <xsl:param name="globalData"/> <xsl:attribute name="class"> <xsl:value-of select="translate(., '.,;: %()[]/\+', '_____________')"/> </xsl:attribute> </xsl:template> <!-- ***************** --> <!-- *** Footnotes *** --> <!-- ***************** --> <xsl:template match="text:note"> <xsl:param name="globalData"/> <!-- get style configuration --> <xsl:variable name="footnoteConfig" select="$globalData/office:styles/text:notes-configuration[@text:note-class=current()/@text:note-class]" /> <xsl:variable name="titlePrefix"> <xsl:choose> <xsl:when test="@text:note-class = 'footnote'"> <xsl:text>Footnote: </xsl:text> </xsl:when> <xsl:otherwise> <xsl:text>Endnote: </xsl:text> </xsl:otherwise> </xsl:choose> </xsl:variable> <!-- write anchor --> <xsl:element name="span"> <xsl:attribute name="class"> <xsl:value-of select="$footnoteConfig/@text:citation-body-style-name"/> </xsl:attribute> <xsl:attribute name="title"> <xsl:value-of select="$titlePrefix"/> <xsl:apply-templates mode="textOnly" select="text:note-body"/> </xsl:attribute> <xsl:element name="a"> <xsl:attribute name="href"> <xsl:value-of select="concat('#', @text:id)"/> </xsl:attribute> <xsl:attribute name="id"> <xsl:value-of select="concat('body_', @text:id)"/> </xsl:attribute> <xsl:apply-templates mode="textOnly" select="text:note-citation"/> </xsl:element> </xsl:element> </xsl:template> <xsl:template match="*" mode="textOnly"> <xsl:apply-templates select="* | text()" mode="textOnly" /> </xsl:template> <xsl:template match="text()" mode="textOnly"> <xsl:value-of select="."/> </xsl:template> <!-- Useful in case of 'style:map', conditional formatting, where a style references to another --> <xsl:key name="textNotes" match="text:note" use="@text:note-class"/> <!-- writing the footer- and endnotes beyond the body --> <xsl:template name="write-text-nodes"> <xsl:param name="globalData"/> <!-- write footnote body --> <xsl:for-each select="key('textNotes', 'footnote')"> <xsl:call-template name="write-text-node"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="footnoteConfig" select="$globalData/office:styles/text:notes-configuration[@text:note-class=current()/@text:note-class]" /> </xsl:call-template> </xsl:for-each> <!-- write endnote body --> <xsl:for-each select="key('textNotes', 'endnote')"> <xsl:call-template name="write-text-node"> <xsl:with-param name="globalData" select="$globalData"/> <xsl:with-param name="footnoteConfig" select="$globalData/office:styles/text:notes-configuration[@text:note-class=current()/@text:note-class]" /> </xsl:call-template> </xsl:for-each> </xsl:template> <xsl:template name="write-text-node"> <xsl:param name="globalData"/> <xsl:param name="footnoteConfig"/> <xsl:apply-templates select="text:note-body/*[1]"> <xsl:with-param name="globalData" select="$globalData" /> <xsl:with-param name="footnotePrefix"> <xsl:element name="span"> <xsl:attribute name="class">footnodeNumber</xsl:attribute> <xsl:element name="a"> <xsl:attribute name="class"> <xsl:value-of select="$footnoteConfig/@text:citation-style-name"/> </xsl:attribute> <xsl:attribute name="id"> <xsl:value-of select="@text:id"/> </xsl:attribute> <xsl:attribute name="href"> <xsl:value-of select="concat('#body_', @text:id)"/> </xsl:attribute> <xsl:apply-templates mode="textOnly" select="text:note-citation"/> </xsl:element> </xsl:element> </xsl:with-param> </xsl:apply-templates> <xsl:apply-templates select="text:note-body/*[position()>1]"> <xsl:with-param name="globalData" select="$globalData" /> </xsl:apply-templates> </xsl:template> <!-- ***************** --> <!-- *** Bookmarks *** --> <!-- ***************** --> <xsl:template match="text:bookmark|text:bookmark-start"> <xsl:element name="a"> <xsl:attribute name="name"> <xsl:value-of select="@text:name"/> </xsl:attribute> </xsl:element> </xsl:template> <xsl:template match="text:bookmark-end"/> <!-- DISABLING this tab handling as the tab width is only relative <xsl:template match="text:tab"> <xsl:param name="globalData"/> <xsl:variable name="tabNo"> <xsl:choose> <xsl:when test="preceding-sibling::text:line-break"> <xsl:call-template name="countTextTab"/> </xsl:when> <xsl:when test="preceding-sibling::text:tab"> <xsl:value-of select="count(preceding-sibling::text:tab)"/> </xsl:when> <xsl:otherwise>1</xsl:otherwise> </xsl:choose> </xsl:variable> <xsl:element name="span"> <xsl:attribute name="style">margin-left:<xsl:value-of select="$globalData/all-doc-styles/style[@style:name = current()/parent::*/@text:style-name]/*/style:tab-stops/style:tab-stop[$tabNo]/@style:position"/>;</xsl:attribute> </xsl:element> </xsl:template> <xsl:template name="countTextTab"> <xsl:param name="tabCount" select="1"/> <xsl:param name="context" select="."/> <xsl:choose> <xsl:when test="preceding-sibling::*[1]"> <xsl:for-each select="preceding-sibling::*[1]"> <xsl:call-template name="countTextTab"> <xsl:with-param name="tabCout"> <xsl:choose> <xsl:when test="name(.) = 'text:tab'"> <xsl:value-of select="$tabCount + 1"/> </xsl:when> <xsl:otherwise> <xsl:value-of select="$tabCount"/> </xsl:otherwise> </xsl:choose> </xsl:with-param> <xsl:with-param name="context" select="preceding-sibling::*[1]" /> </xsl:call-template> </xsl:for-each> </xsl:when> <xsl:otherwise> <xsl:value-of select="$tabCount"/> </xsl:otherwise> </xsl:choose> </xsl:template> --> <!-- MathML --> <xsl:template match="draw:object[math:math]"> <math xmlns="http://www.w3.org/1998/Math/MathML"> <xsl:apply-templates select="math:math/math:semantics/*" mode="math"/> </math> </xsl:template> <xsl:template match="*" mode="math"> <xsl:element name="{local-name()}" namespace="http://www.w3.org/1998/Math/MathML"> <xsl:apply-templates select="@*|node()" mode="math"/> </xsl:element> </xsl:template> <xsl:template match="@*" mode="math"> <xsl:attribute name="{local-name()}"> <xsl:value-of select="."/> </xsl:attribute> </xsl:template> <xsl:template match="math:annotation" mode="math"/> </xsl:stylesheet>