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/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : C:/Program Files (x86)/OpenOffice 4/share/xslt/export/xhtml/body.xsl
<?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) &gt; 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)) &gt; 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
					&#160; 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;">&#160;</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) &gt; 0 and count($tabStops/style:tab-stop) &lt; 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>&#160;</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 (&nbsp) 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>&#160;</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;">&#160;</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) &gt; 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)) &lt; 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 &gt; 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>&#160;</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 &gt; 0.5) or
					($svgX &gt; 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 &lt; 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)), '&#xA;&amp;&lt;&gt;.,;: %()[]/\+', '___________________________')"/>
			</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 &lt; $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 &lt; $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 &gt; 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 &gt; 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 &gt; 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 &gt; $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>&#160;</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 &gt; $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>&#160;</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 &lt; $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 &lt; $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>&#160;</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>&#160;</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)), '&#xA;&amp;&lt;&gt;.,;: %()[]/\+', '___________________________')"/>
				</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>&#160;</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()&gt;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>