glfs/stylesheets/lfs-xsl/xhtml/lfs-titles.xsl
Pierre Labastie 0d7e9a2687 Fix output of anchors with same id in sect3
The template for sect3.titlepage generates:
<h3 class="sect3">
  <a id="{id of sect3}" name="{id of sect3}"></a>
  <h4 class="title">
    <a id="{id of sect3}" name="{id of sect3}">i{title of sect3}</a>
  </h4>
</h3>
resulting in double definition of the same id, which is a validity error
in XML documents.
Replace with the same template as for sect2, using h3 instead of h2.
2024-01-20 08:24:10 +01:00

197 lines
6.7 KiB
XML

<?xml version='1.0' encoding='UTF-8'?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns="http://www.w3.org/1999/xhtml"
version="1.0">
<!-- This stylesheet controls the h* xhtml tags used for several titles -->
<!-- preface.titlepage:
Uses h1 and removed a lot of unneeded code.
No label in preface. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="preface.titlepage">
<h1 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:value-of select="title"/>
</h1>
</xsl:template>
<!-- part.titlepage:
Uses h1 and removed a lot of unneeded code.
When sections are not labeled, we want the part label in TOC
but not in titlepage. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="part.titlepage">
<h1 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:if test="$section.autolabel != 0">
<xsl:apply-templates select="." mode="label.markup"/>
<xsl:text>. </xsl:text>
</xsl:if>
<xsl:value-of select="title"/>
</h1>
</xsl:template>
<!-- partintro.titlepage:
Uses h2 and removed a lot of unneeded code. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="partintro.titlepage">
<xsl:if test="title">
<h2 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:value-of select="title"/>
</h2>
</xsl:if>
</xsl:template>
<!-- appendix.titlepage:
Uses h1 and removed a lot of unneeded code.
When sections are not labeled, we want the appendix label in TOC
but not in titlepage. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="appendix.titlepage">
<h1 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:if test="$section.autolabel != 0">
<xsl:apply-templates select="." mode="label.markup"/>
<xsl:text>. </xsl:text>
</xsl:if>
<xsl:value-of select="title"/>
</h1>
</xsl:template>
<!-- chapter.titlepage:
Uses h1 and removed a lot of unneeded code.
When sections are not labeled, we want the chapter label in TOC
but not in titlepage. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="chapter.titlepage">
<h1 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:if test="$section.autolabel != 0">
<xsl:apply-templates select="." mode="label.markup"/>
<xsl:text>. </xsl:text>
</xsl:if>
<xsl:value-of select="title"/>
</h1>
</xsl:template>
<!-- sect1.titlepage:
Uses h1 and removed a lot of unneeded code. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="sect1.titlepage">
<h1 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:if test="$section.autolabel != 0">
<xsl:apply-templates select="." mode="label.markup"/>
<xsl:text>. </xsl:text>
</xsl:if>
<xsl:value-of select="title"/>
</h1>
</xsl:template>
<!-- sect2.titlepage:
Uses h2 and removed a lot of unneeded code.
Skip empty titles.
No label in preface. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="sect2.titlepage">
<xsl:choose>
<xsl:when test="string-length(title) = 0"/>
<xsl:otherwise>
<h2 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:if test="not(ancestor::preface) and $section.autolabel != 0">
<xsl:apply-templates select="." mode="label.markup"/>
<xsl:text>. </xsl:text>
</xsl:if>
<xsl:value-of select="title"/>
</h2>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
<!-- sect3.titlepage:
Same as sect2 except it uses h3 -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="sect3.titlepage">
<xsl:choose>
<xsl:when test="string-length(title) = 0"/>
<xsl:otherwise>
<h3 class="{name(.)}">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:if test="not(ancestor::preface) and $section.autolabel != 0">
<xsl:apply-templates select="." mode="label.markup"/>
<xsl:text>. </xsl:text>
</xsl:if>
<xsl:value-of select="title"/>
</h3>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
<!-- dedication.titlepage:
Uses h2 and removed a lot of unneeded code. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="dedication.titlepage">
<h2>
<xsl:value-of select="title"/>
</h2>
</xsl:template>
<!-- bridgehead:
We use always renderas attributes and want the output h* level
matching the defined sect* level.
Create the anchor only if there is an @id. -->
<!-- The original template is in {docbook-xsl}/xhtml/sections.xsl -->
<xsl:template match="bridgehead">
<xsl:variable name="hlevel">
<xsl:choose>
<xsl:when test="@renderas = 'sect1'">1</xsl:when>
<xsl:when test="@renderas = 'sect2'">2</xsl:when>
<xsl:when test="@renderas = 'sect3'">3</xsl:when>
<xsl:when test="@renderas = 'sect4'">4</xsl:when>
<xsl:when test="@renderas = 'sect5'">5</xsl:when>
</xsl:choose>
</xsl:variable>
<xsl:element name="h{$hlevel}" namespace="http://www.w3.org/1999/xhtml">
<xsl:if test="@id">
<a id="{@id}" name="{@id}"/>
</xsl:if>
<xsl:apply-templates/>
</xsl:element>
</xsl:template>
<!-- book.titlepage.verso:
Process bookinfo/bibliosource from here. -->
<!-- The original template is in {docbook-xsl}/xhtml/titlepage.templates.xsl -->
<xsl:template name="book.titlepage.verso">
<xsl:apply-templates select="bookinfo/bibliosource"/>
</xsl:template>
<!-- bookinfo/bibliosource:
Self-made template to handle bibliosource when inside bookinfo. -->
<xsl:template match="bookinfo/bibliosource">
<p class="copyright">
<xsl:apply-templates/>
</p>
</xsl:template>
</xsl:stylesheet>