lib/isodoc/cc/cc.standard.xsl in metanorma-cc-2.0.0 vs lib/isodoc/cc/cc.standard.xsl in metanorma-cc-2.0.1
- old
+ new
@@ -44,11 +44,11 @@
<xsl:call-template name="getLang"/>
</xsl:variable>
<xsl:template match="/">
<xsl:call-template name="namespaceCheck"/>
- <fo:root font-family="Source Sans Pro, STIX Two Math, Source Han Sans" font-size="10.5pt" xml:lang="{$lang}">
+ <fo:root xsl:use-attribute-sets="root-style" xml:lang="{$lang}">
<fo:layout-master-set>
<!-- Cover page -->
<fo:simple-page-master master-name="cover-page" page-width="{$pageWidth}mm" page-height="{$pageHeight}mm">
<fo:region-body margin-top="23.5mm" margin-bottom="10mm" margin-left="19mm" margin-right="19mm"/>
<fo:region-before region-name="cover-page-header" extent="23.5mm"/>
@@ -315,14 +315,11 @@
</xsl:template>
<!-- ============================= -->
<!-- CONTENTS -->
<!-- ============================= -->
- <xsl:template match="node()" mode="contents">
- <xsl:apply-templates mode="contents"/>
- </xsl:template>
-
+
<!-- element with title -->
<xsl:template match="*[csd:title]" mode="contents">
<xsl:variable name="level">
<xsl:call-template name="getLevel">
<xsl:with-param name="depth" select="csd:title/@depth"/>
@@ -506,47 +503,11 @@
<xsl:template match="csd:p/csd:fn/csd:p">
<xsl:apply-templates/>
</xsl:template>
- <xsl:template match="csd:bibitem">
- <fo:block id="{@id}" margin-bottom="6pt"> <!-- 12 pt -->
- <xsl:call-template name="processBibitem"/>
- </fo:block>
- </xsl:template>
-
- <xsl:template match="csd:bibitem/csd:note" priority="2">
- <fo:footnote>
- <xsl:variable name="number">
- <xsl:choose>
- <xsl:when test="ancestor::csd:references[preceding-sibling::csd:references]">
- <xsl:number level="any" count="csd:references[preceding-sibling::csd:references]//csd:bibitem/csd:note"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:number level="any" count="csd:bibitem/csd:note"/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
- <fo:inline font-size="65%" keep-with-previous.within-line="always" vertical-align="super"> <!-- 60% baseline-shift="35%" -->
- <fo:basic-link internal-destination="{generate-id()}" fox:alt-text="footnote {$number}">
- <xsl:value-of select="$number"/><!-- <xsl:text>)</xsl:text> -->
- </fo:basic-link>
- </fo:inline>
- <fo:footnote-body>
- <fo:block font-size="10pt" margin-bottom="12pt" start-indent="0pt">
- <fo:inline id="{generate-id()}" keep-with-next.within-line="always" font-size="60%" vertical-align="super"><!-- baseline-shift="30%" padding-right="9mm" alignment-baseline="hanging" -->
- <xsl:value-of select="$number"/><!-- <xsl:text>)</xsl:text> -->
- </fo:inline>
- <xsl:apply-templates/>
- </fo:block>
- </fo:footnote-body>
- </fo:footnote>
- </xsl:template>
-
-
-
<xsl:template match="csd:ul | csd:ol" mode="ul_ol">
<fo:list-block provisional-distance-between-starts="6.5mm" margin-bottom="12pt">
<xsl:if test="ancestor::csd:ol">
<xsl:attribute name="margin-bottom">0pt</xsl:attribute>
</xsl:if>
@@ -600,63 +561,22 @@
<xsl:variable name="levelTerm">
<xsl:call-template name="getLevelTermName"/>
</xsl:variable>
<fo:block font-size="{$font-size}" line-height="1.1" role="H{$levelTerm}">
<fo:block font-weight="bold" keep-with-next="always">
- <xsl:apply-templates select="ancestor::csd:term[1]/csd:name" mode="presentation"/>
+ <xsl:apply-templates select="ancestor::csd:term[1]/csd:name"/>
</fo:block>
<fo:block font-weight="bold" keep-with-next="always">
<xsl:call-template name="setStyle_preferred"/>
<xsl:apply-templates/>
</fo:block>
</fo:block>
</xsl:template>
-
-
- <!-- <xsl:template match="csd:references[@id = '_bibliography']"> -->
- <xsl:template match="csd:references[not(@normative='true')]">
- <fo:block break-after="page"/>
- <fo:block id="{@id}">
- <xsl:apply-templates/>
- </fo:block>
- </xsl:template>
-
-
- <!-- Example: [1] ISO 9:1995, Information and documentation – Transliteration of Cyrillic characters into Latin characters – Slavic and non-Slavic languages -->
- <!-- <xsl:template match="csd:references[@id = '_bibliography']/csd:bibitem"> -->
- <xsl:template match="csd:references[not(@normative='true')]/csd:bibitem">
- <fo:list-block margin-bottom="12pt" provisional-distance-between-starts="12mm">
- <fo:list-item>
- <fo:list-item-label end-indent="label-end()">
- <fo:block>
- <fo:inline id="{@id}">
- <xsl:value-of select="*[local-name()='docidentifier'][@type = 'metanorma-ordinal']"/>
- <xsl:if test="not(*[local-name()='docidentifier'][@type = 'metanorma-ordinal'])">
- <xsl:number format="[1]"/>
- </xsl:if>
- </fo:inline>
- </fo:block>
- </fo:list-item-label>
- <fo:list-item-body start-indent="body-start()">
- <fo:block>
- <xsl:call-template name="processBibitem"/>
- </fo:block>
- </fo:list-item-body>
- </fo:list-item>
- </fo:list-block>
- </xsl:template>
- <!-- <xsl:template match="csd:references[@id = '_bibliography']/csd:bibitem/csd:title"> -->
- <xsl:template match="csd:references/csd:bibitem/csd:title">
- <fo:inline font-style="italic">
- <xsl:apply-templates/>
- </fo:inline>
- </xsl:template>
-
<xsl:template match="csd:xref" priority="2">
<fo:basic-link internal-destination="{@target}" fox:alt-text="{@target}">
<xsl:if test="not(starts-with(text(), 'Figure') or starts-with(text(), 'Table'))">
<xsl:attribute name="color">blue</xsl:attribute>
<xsl:attribute name="text-decoration">underline</xsl:attribute>
@@ -664,21 +584,10 @@
<xsl:apply-templates/>
</fo:basic-link>
</xsl:template>
-
- <xsl:template match="csd:admonition">
- <fo:block margin-bottom="12pt" font-weight="bold"> <!-- text-align="center" -->
- <xsl:value-of select="java:toUpperCase(java:java.lang.String.new(@type))"/>
- <xsl:text> — </xsl:text>
- <xsl:apply-templates/>
- </fo:block>
- </xsl:template>
-
-
-
<xsl:template match="csd:formula/csd:stem">
<fo:block margin-top="6pt" margin-bottom="12pt">
<fo:table table-layout="fixed" width="100%">
<fo:table-column column-width="95%"/>
<fo:table-column column-width="5%"/>
@@ -689,11 +598,11 @@
<xsl:apply-templates/>
</fo:block>
</fo:table-cell>
<fo:table-cell display-align="center">
<fo:block text-align="right">
- <xsl:apply-templates select="../csd:name" mode="presentation"/>
+ <xsl:apply-templates select="../csd:name" mode="formula_number"/>
</fo:block>
</fo:table-cell>
</fo:table-row>
</fo:table-body>
</fo:table>
@@ -754,43 +663,38 @@
</fo:block-container>
</fo:static-content>
</xsl:template>
-<xsl:variable name="titles" select="xalan:nodeset($titles_)"/><xsl:variable name="titles_">
+<xsl:variable name="titles_">
<title-edition lang="en">
- <xsl:text>Edition </xsl:text>
-
-
+ <xsl:text>Edition </xsl:text>
+
</title-edition>
<title-edition lang="fr">
-
- <xsl:text>Édition </xsl:text>
-
+ <xsl:text>Édition </xsl:text>
</title-edition>
-
<!-- These titles of Table of contents renders different than determined in localized-strings -->
<title-toc lang="en">
<xsl:text>Contents</xsl:text>
</title-toc>
<title-toc lang="fr">
+ <xsl:text>Sommaire</xsl:text>
+ </title-toc>
+ <title-toc lang="zh">
- <xsl:text>Sommaire</xsl:text>
-
+ <xsl:text>Contents</xsl:text>
+
</title-toc>
-
- <title-toc lang="zh">Contents</title-toc>
-
-
<title-descriptors lang="en">Descriptors</title-descriptors>
<title-part lang="en">
@@ -802,16 +706,12 @@
</title-part>
<title-part lang="zh">第 # 部分:</title-part>
- <title-subpart lang="en">
-
- </title-subpart>
- <title-subpart lang="fr">
-
- </title-subpart>
+ <title-subpart lang="en">Sub-part #</title-subpart>
+ <title-subpart lang="fr">Partie de sub #</title-subpart>
<title-list-tables lang="en">List of Tables</title-list-tables>
<title-list-figures lang="en">List of Figures</title-list-figures>
@@ -822,11 +722,11 @@
<title-summary lang="en">Summary</title-summary>
<title-continued lang="en">(continued)</title-continued>
<title-continued lang="fr">(continué)</title-continued>
- </xsl:variable><xsl:variable name="bibdata">
+ </xsl:variable><xsl:variable name="titles" select="xalan:nodeset($titles_)"/><xsl:variable name="bibdata">
<xsl:copy-of select="//*[contains(local-name(), '-standard')]/*[local-name() = 'bibdata']"/>
<xsl:copy-of select="//*[contains(local-name(), '-standard')]/*[local-name() = 'localized-strings']"/>
</xsl:variable><xsl:variable name="tab_zh"> </xsl:variable><xsl:template name="getTitle">
<xsl:param name="name"/>
<xsl:param name="lang"/>
@@ -851,19 +751,39 @@
</xsl:otherwise>
</xsl:choose>
</xsl:template><xsl:variable name="lower">abcdefghijklmnopqrstuvwxyz</xsl:variable><xsl:variable name="upper">ABCDEFGHIJKLMNOPQRSTUVWXYZ</xsl:variable><xsl:variable name="en_chars" select="concat($lower,$upper,',.`1234567890-=~!@#$%^*()_+[]{}\|?/')"/><xsl:variable name="linebreak" select="'
'"/><xsl:attribute-set name="root-style">
+
+
+ <xsl:attribute name="font-family">Source Sans Pro, STIX Two Math, Source Han Sans</xsl:attribute>
+ <xsl:attribute name="font-size">10.5pt</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
</xsl:attribute-set><xsl:attribute-set name="link-style">
<xsl:attribute name="color">blue</xsl:attribute>
<xsl:attribute name="text-decoration">underline</xsl:attribute>
+ </xsl:attribute-set><xsl:attribute-set name="sourcecode-container-style">
+ <xsl:attribute name="margin-left">0mm</xsl:attribute>
+
</xsl:attribute-set><xsl:attribute-set name="sourcecode-style">
<xsl:attribute name="white-space">pre</xsl:attribute>
<xsl:attribute name="wrap-option">wrap</xsl:attribute>
<xsl:attribute name="role">Code</xsl:attribute>
@@ -873,14 +793,21 @@
<xsl:attribute name="margin-bottom">6pt</xsl:attribute>
<xsl:attribute name="keep-with-next">always</xsl:attribute>
+
+
+
+
+
+
+
</xsl:attribute-set><xsl:attribute-set name="permission-style">
</xsl:attribute-set><xsl:attribute-set name="permission-name-style">
</xsl:attribute-set><xsl:attribute-set name="permission-label-style">
@@ -988,11 +915,64 @@
</xsl:attribute-set><xsl:variable name="table-border_">
- </xsl:variable><xsl:variable name="table-border" select="normalize-space($table-border_)"/><xsl:attribute-set name="table-name-style">
+ </xsl:variable><xsl:variable name="table-border" select="normalize-space($table-border_)"/><xsl:attribute-set name="table-container-style">
+ <xsl:attribute name="margin-left">0mm</xsl:attribute>
+ <xsl:attribute name="margin-right">0mm</xsl:attribute>
+
+
+
+
+
+ <xsl:attribute name="font-size">10pt</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-style">
+ <xsl:attribute name="table-omit-footer-at-break">true</xsl:attribute>
+ <xsl:attribute name="table-layout">fixed</xsl:attribute>
+ <xsl:attribute name="margin-left">0mm</xsl:attribute>
+ <xsl:attribute name="margin-right">0mm</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-name-style">
<xsl:attribute name="keep-with-next">always</xsl:attribute>
<xsl:attribute name="font-weight">bold</xsl:attribute>
<xsl:attribute name="text-align">center</xsl:attribute>
@@ -1008,12 +988,153 @@
+ </xsl:attribute-set><xsl:attribute-set name="table-row-style">
+ <xsl:attribute name="min-height">4mm</xsl:attribute>
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-header-row-style" use-attribute-sets="table-row-style">
+ <xsl:attribute name="font-weight">bold</xsl:attribute>
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-footer-row-style" use-attribute-sets="table-row-style">
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-body-row-style" use-attribute-sets="table-row-style">
+
+ </xsl:attribute-set><xsl:attribute-set name="table-header-cell-style">
+ <xsl:attribute name="font-weight">bold</xsl:attribute>
+ <xsl:attribute name="border">solid black 1pt</xsl:attribute>
+ <xsl:attribute name="padding-left">1mm</xsl:attribute>
+ <xsl:attribute name="display-align">center</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-cell-style">
+ <xsl:attribute name="display-align">center</xsl:attribute>
+ <xsl:attribute name="border">solid black 1pt</xsl:attribute>
+ <xsl:attribute name="padding-left">1mm</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
</xsl:attribute-set><xsl:attribute-set name="table-footer-cell-style">
+ <xsl:attribute name="border">solid black 1pt</xsl:attribute>
+ <xsl:attribute name="padding-left">1mm</xsl:attribute>
+ <xsl:attribute name="padding-right">1mm</xsl:attribute>
+ <xsl:attribute name="padding-top">1mm</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-note-style">
+ <xsl:attribute name="font-size">10pt</xsl:attribute>
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-fn-style">
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-fn-number-style">
+ <xsl:attribute name="font-size">80%</xsl:attribute>
+ <xsl:attribute name="padding-right">5mm</xsl:attribute>
+
+ <xsl:attribute name="vertical-align">super</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="fn-container-body-style">
+ <xsl:attribute name="text-indent">0</xsl:attribute>
+ <xsl:attribute name="start-indent">0</xsl:attribute>
+
+
+ </xsl:attribute-set><xsl:attribute-set name="table-fn-body-style">
+
+ </xsl:attribute-set><xsl:attribute-set name="figure-fn-number-style">
+ <xsl:attribute name="font-size">80%</xsl:attribute>
+ <xsl:attribute name="padding-right">5mm</xsl:attribute>
+ <xsl:attribute name="vertical-align">super</xsl:attribute>
+
+ </xsl:attribute-set><xsl:attribute-set name="figure-fn-body-style">
+ <xsl:attribute name="text-align">justify</xsl:attribute>
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+
+ </xsl:attribute-set><xsl:attribute-set name="dt-row-style">
+
+
+ </xsl:attribute-set><xsl:attribute-set name="dt-style">
+ <xsl:attribute name="margin-top">6pt</xsl:attribute>
+
+ <xsl:attribute name="margin-left">7mm</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
</xsl:attribute-set><xsl:attribute-set name="appendix-style">
<xsl:attribute name="font-size">12pt</xsl:attribute>
<xsl:attribute name="font-weight">bold</xsl:attribute>
<xsl:attribute name="margin-top">12pt</xsl:attribute>
@@ -1080,10 +1201,11 @@
</xsl:attribute-set><xsl:attribute-set name="table-note-name-style">
+ <xsl:attribute name="padding-right">2mm</xsl:attribute>
</xsl:attribute-set><xsl:attribute-set name="note-p-style">
@@ -1146,17 +1268,22 @@
+ </xsl:attribute-set><xsl:attribute-set name="termsource-text-style">
+
+
</xsl:attribute-set><xsl:attribute-set name="origin-style">
</xsl:attribute-set><xsl:attribute-set name="term-style">
+ </xsl:attribute-set><xsl:attribute-set name="figure-style">
+
</xsl:attribute-set><xsl:attribute-set name="figure-name-style">
@@ -1253,10 +1380,21 @@
</xsl:attribute-set><xsl:attribute-set name="list-style">
</xsl:attribute-set><xsl:attribute-set name="toc-style">
<xsl:attribute name="line-height">135%</xsl:attribute>
+ </xsl:attribute-set><xsl:attribute-set name="fn-reference-style">
+ <xsl:attribute name="font-size">80%</xsl:attribute>
+ <xsl:attribute name="keep-with-previous.within-line">always</xsl:attribute>
+
+
+
+
+
+
+
+
</xsl:attribute-set><xsl:attribute-set name="fn-style">
<xsl:attribute name="keep-with-previous.within-line">always</xsl:attribute>
</xsl:attribute-set><xsl:attribute-set name="fn-num-style">
<xsl:attribute name="keep-with-previous.within-line">always</xsl:attribute>
@@ -1324,34 +1462,196 @@
- </xsl:attribute-set><xsl:variable name="border-block-added">2.5pt solid rgb(0, 176, 80)</xsl:variable><xsl:variable name="border-block-deleted">2.5pt solid rgb(255, 0, 0)</xsl:variable><xsl:variable name="ace_tag">ace-tag_</xsl:variable><xsl:template name="OLD_processPrefaceSectionsDefault_Contents">
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='abstract']" mode="contents"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='foreword']" mode="contents"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='introduction']" mode="contents"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name() != 'abstract' and local-name() != 'foreword' and local-name() != 'introduction' and local-name() != 'acknowledgements']" mode="contents"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='acknowledgements']" mode="contents"/>
- </xsl:template><xsl:template name="processPrefaceSectionsDefault_Contents">
+ </xsl:attribute-set><xsl:attribute-set name="admonition-style">
+
+
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+ <xsl:attribute name="font-weight">bold</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="admonition-container-style">
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="admonition-name-style">
+ <xsl:attribute name="keep-with-next">always</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="admonition-p-style">
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-normative-style">
+
+
+
+
+ <xsl:attribute name="margin-bottom">6pt</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-normative-list-style">
+ <xsl:attribute name="provisional-distance-between-starts">12mm</xsl:attribute>
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-non-normative-style">
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-non-normative-list-style">
+ <xsl:attribute name="provisional-distance-between-starts">12mm</xsl:attribute>
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-normative-list-body-style">
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-non-normative-list-body-style">
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-note-fn-style">
+ <xsl:attribute name="keep-with-previous.within-line">always</xsl:attribute>
+ <xsl:attribute name="font-size">65%</xsl:attribute>
+
+
+
+
+ <xsl:attribute name="vertical-align">super</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-note-fn-number-style">
+ <xsl:attribute name="keep-with-next.within-line">always</xsl:attribute>
+
+
+
+
+ <xsl:attribute name="font-size">60%</xsl:attribute>
+ <xsl:attribute name="vertical-align">super</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="bibitem-note-fn-body-style">
+ <xsl:attribute name="font-size">10pt</xsl:attribute>
+ <xsl:attribute name="margin-bottom">12pt</xsl:attribute>
+ <xsl:attribute name="start-indent">0pt</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:attribute-set><xsl:attribute-set name="references-non-normative-style">
+
+
+
+ </xsl:attribute-set><xsl:variable name="border-block-added">2.5pt solid rgb(0, 176, 80)</xsl:variable><xsl:variable name="border-block-deleted">2.5pt solid rgb(255, 0, 0)</xsl:variable><xsl:variable name="ace_tag">ace-tag_</xsl:variable><xsl:template name="processPrefaceSectionsDefault_Contents">
<xsl:for-each select="/*/*[local-name()='preface']/*">
<xsl:sort select="@displayorder" data-type="number"/>
<xsl:apply-templates select="." mode="contents"/>
</xsl:for-each>
- </xsl:template><xsl:template name="OLD_processMainSectionsDefault_Contents">
- <xsl:apply-templates select="/*/*[local-name()='sections']/*[local-name()='clause'][@type='scope']" mode="contents"/>
-
- <!-- Normative references -->
- <xsl:apply-templates select="/*/*[local-name()='bibliography']/*[local-name()='references'][@normative='true'] | /*/*[local-name()='bibliography']/*[local-name()='clause'][*[local-name()='references'][@normative='true']]" mode="contents"/>
- <!-- Terms and definitions -->
- <xsl:apply-templates select="/*/*[local-name()='sections']/*[local-name()='terms'] | /*/*[local-name()='sections']/*[local-name()='clause'][.//*[local-name()='terms']] | /*/*[local-name()='sections']/*[local-name()='definitions'] | /*/*[local-name()='sections']/*[local-name()='clause'][.//*[local-name()='definitions']]" mode="contents"/>
- <!-- Another main sections -->
- <xsl:apply-templates select="/*/*[local-name()='sections']/*[local-name() != 'terms' and local-name() != 'definitions' and not(@type='scope') and not(local-name() = 'clause' and .//*[local-name()='terms']) and not(local-name() = 'clause' and .//*[local-name()='definitions'])]" mode="contents"/>
- <xsl:apply-templates select="/*/*[local-name()='annex']" mode="contents"/>
- <!-- Bibliography -->
- <xsl:apply-templates select="/*/*[local-name()='bibliography']/*[local-name()='references'][not(@normative='true')] | /*/*[local-name()='bibliography']/*[local-name()='clause'][*[local-name()='references'][not(@normative='true')]]" mode="contents"/>
-
</xsl:template><xsl:template name="processMainSectionsDefault_Contents">
<xsl:for-each select="/*/*[local-name()='sections']/* | /*/*[local-name()='bibliography']/*[local-name()='references'][@normative='true'] | /*/*[local-name()='bibliography']/*[local-name()='clause'][*[local-name()='references'][@normative='true']]">
<xsl:sort select="@displayorder" data-type="number"/>
<xsl:apply-templates select="." mode="contents"/>
@@ -1364,33 +1664,15 @@
<xsl:for-each select="/*/*[local-name()='bibliography']/*[not(@normative='true') and not(*[local-name()='references'][@normative='true'])] | /*/*[local-name()='bibliography']/*[local-name()='clause'][*[local-name()='references'][not(@normative='true')]]">
<xsl:sort select="@displayorder" data-type="number"/>
<xsl:apply-templates select="." mode="contents"/>
</xsl:for-each>
- </xsl:template><xsl:template name="OLD_processPrefaceSectionsDefault">
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='abstract']"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='foreword']"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='introduction']"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name() != 'abstract' and local-name() != 'foreword' and local-name() != 'introduction' and local-name() != 'acknowledgements']"/>
- <xsl:apply-templates select="/*/*[local-name()='preface']/*[local-name()='acknowledgements']"/>
</xsl:template><xsl:template name="processPrefaceSectionsDefault">
<xsl:for-each select="/*/*[local-name()='preface']/*">
<xsl:sort select="@displayorder" data-type="number"/>
<xsl:apply-templates select="."/>
</xsl:for-each>
- </xsl:template><xsl:template name="OLD_processMainSectionsDefault">
- <xsl:apply-templates select="/*/*[local-name()='sections']/*[local-name()='clause'][@type='scope']"/>
-
- <!-- Normative references -->
- <xsl:apply-templates select="/*/*[local-name()='bibliography']/*[local-name()='references'][@normative='true']"/>
- <!-- Terms and definitions -->
- <xsl:apply-templates select="/*/*[local-name()='sections']/*[local-name()='terms'] | /*/*[local-name()='sections']/*[local-name()='clause'][.//*[local-name()='terms']] | /*/*[local-name()='sections']/*[local-name()='definitions'] | /*/*[local-name()='sections']/*[local-name()='clause'][.//*[local-name()='definitions']]"/>
- <!-- Another main sections -->
- <xsl:apply-templates select="/*/*[local-name()='sections']/*[local-name() != 'terms' and local-name() != 'definitions' and not(@type='scope') and not(local-name() = 'clause' and .//*[local-name()='terms']) and not(local-name() = 'clause' and .//*[local-name()='definitions'])]"/>
- <xsl:apply-templates select="/*/*[local-name()='annex']"/>
- <!-- Bibliography -->
- <xsl:apply-templates select="/*/*[local-name()='bibliography']/*[local-name()='references'][not(@normative='true')]"/>
</xsl:template><xsl:template name="processMainSectionsDefault">
<xsl:for-each select="/*/*[local-name()='sections']/* | /*/*[local-name()='bibliography']/*[local-name()='references'][@normative='true']">
<xsl:sort select="@displayorder" data-type="number"/>
<xsl:apply-templates select="."/>
@@ -1423,145 +1705,113 @@
<xsl:variable name="simple-table">
<xsl:call-template name="getSimpleTable"/>
</xsl:variable>
- <!-- <xsl:if test="$namespace = 'bipm'">
- <fo:block> </fo:block>
- </xsl:if> -->
-
<!-- Display table's name before table as standalone block -->
<!-- $namespace = 'iso' or -->
- <xsl:apply-templates select="*[local-name()='name']" mode="presentation"/>
+ <xsl:apply-templates select="*[local-name()='name']"/> <!-- table's title rendered before table -->
+
-
-
-
- <xsl:call-template name="fn_name_display"/>
-
+ <xsl:call-template name="table_name_fn_display"/>
<xsl:variable name="cols-count" select="count(xalan:nodeset($simple-table)/*/tr[1]/td)"/>
- <!-- <xsl:variable name="cols-count">
- <xsl:choose>
- <xsl:when test="*[local-name()='thead']">
- <xsl:call-template name="calculate-columns-numbers">
- <xsl:with-param name="table-row" select="*[local-name()='thead']/*[local-name()='tr'][1]"/>
- </xsl:call-template>
- </xsl:when>
- <xsl:otherwise>
- <xsl:call-template name="calculate-columns-numbers">
- <xsl:with-param name="table-row" select="*[local-name()='tbody']/*[local-name()='tr'][1]"/>
- </xsl:call-template>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:variable> -->
- <!-- cols-count=<xsl:copy-of select="$cols-count"/> -->
- <!-- cols-count2=<xsl:copy-of select="$cols-count2"/> -->
-
<xsl:variable name="colwidths">
<xsl:if test="not(*[local-name()='colgroup']/*[local-name()='col'])">
<xsl:call-template name="calculate-column-widths">
<xsl:with-param name="cols-count" select="$cols-count"/>
<xsl:with-param name="table" select="$simple-table"/>
</xsl:call-template>
</xsl:if>
</xsl:variable>
<!-- colwidths=<xsl:copy-of select="$colwidths"/> -->
- <!-- <xsl:variable name="colwidths2">
- <xsl:call-template name="calculate-column-widths">
- <xsl:with-param name="cols-count" select="$cols-count"/>
- </xsl:call-template>
- </xsl:variable> -->
- <!-- cols-count=<xsl:copy-of select="$cols-count"/>
- colwidthsNew=<xsl:copy-of select="$colwidths"/>
- colwidthsOld=<xsl:copy-of select="$colwidths2"/>z -->
-
- <xsl:variable name="margin-left">
+ <xsl:variable name="margin-side">
<xsl:choose>
<xsl:when test="sum(xalan:nodeset($colwidths)//column) > 75">15</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
- <fo:block-container margin-left="-{$margin-left}mm" margin-right="-{$margin-left}mm">
+ <fo:block-container xsl:use-attribute-sets="table-container-style">
+
+ <xsl:attribute name="margin-left"><xsl:value-of select="-$margin-side"/>mm</xsl:attribute>
+ <xsl:attribute name="margin-right"><xsl:value-of select="-$margin-side"/>mm</xsl:attribute>
- <xsl:attribute name="font-size">10pt</xsl:attribute>
+
+
-
-
-
+
-
+
+ <!-- end table block-container attributes -->
-
-
-
-
<!-- display table's name before table for PAS inside block-container (2-columnn layout) -->
+ <xsl:variable name="table_width_default">100%</xsl:variable>
<xsl:variable name="table_width">
<!-- for centered table always 100% (@width will be set for middle/second cell of outer table) -->
- 100%
-
-
+ <xsl:value-of select="$table_width_default"/>
</xsl:variable>
+
<xsl:variable name="table_attributes">
- <attribute name="table-layout">fixed</attribute>
- <attribute name="width"><xsl:value-of select="normalize-space($table_width)"/></attribute>
- <attribute name="margin-left"><xsl:value-of select="$margin-left"/>mm</attribute>
- <attribute name="margin-right"><xsl:value-of select="$margin-left"/>mm</attribute>
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+ <xsl:element name="table_attributes" use-attribute-sets="table-style">
+ <xsl:attribute name="width"><xsl:value-of select="normalize-space($table_width)"/></xsl:attribute>
+
+
+ <xsl:attribute name="margin-left"><xsl:value-of select="$margin-side"/>mm</xsl:attribute>
+ <xsl:attribute name="margin-right"><xsl:value-of select="$margin-side"/>mm</xsl:attribute>
+
+
+
+
+
+
+
+
+
+
+
+
+
+ </xsl:element>
</xsl:variable>
- <fo:table id="{@id}" table-omit-footer-at-break="true">
+ <fo:table id="{@id}">
- <xsl:for-each select="xalan:nodeset($table_attributes)/attribute">
- <xsl:attribute name="{@name}">
+ <xsl:for-each select="xalan:nodeset($table_attributes)/table_attributes/@*">
+ <xsl:attribute name="{local-name()}">
<xsl:value-of select="."/>
</xsl:attribute>
</xsl:for-each>
<xsl:variable name="isNoteOrFnExist" select="./*[local-name()='note'] or .//*[local-name()='fn'][local-name(..) != 'name']"/>
<xsl:if test="$isNoteOrFnExist = 'true'">
<xsl:attribute name="border-bottom">0pt solid black</xsl:attribute> <!-- set 0pt border, because there is a separete table below for footer -->
</xsl:if>
-
<xsl:choose>
<xsl:when test="*[local-name()='colgroup']/*[local-name()='col']">
<xsl:for-each select="*[local-name()='colgroup']/*[local-name()='col']">
<fo:table-column column-width="{@width}"/>
</xsl:for-each>
@@ -1583,11 +1833,11 @@
<xsl:choose>
<xsl:when test="not(*[local-name()='tbody']) and *[local-name()='thead']">
<xsl:apply-templates select="*[local-name()='thead']" mode="process_tbody"/>
</xsl:when>
<xsl:otherwise>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</xsl:otherwise>
</xsl:choose>
</fo:table>
@@ -1598,29 +1848,10 @@
<xsl:with-param name="colwidths" select="$colwidths"/>
<xsl:with-param name="colgroup" select="$colgroup"/>
</xsl:call-template>
</xsl:for-each>
- <!-- insert footer as table -->
- <!-- <fo:table>
- <xsl:for-each select="xalan::nodeset($table_attributes)/attribute">
- <xsl:attribute name="{@name}">
- <xsl:value-of select="."/>
- </xsl:attribute>
- </xsl:for-each>
-
- <xsl:for-each select="xalan:nodeset($colwidths)//column">
- <xsl:choose>
- <xsl:when test=". = 1 or . = 0">
- <fo:table-column column-width="proportional-column-width(2)"/>
- </xsl:when>
- <xsl:otherwise>
- <fo:table-column column-width="proportional-column-width({.})"/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:for-each>
- </fo:table>-->
@@ -1677,22 +1908,21 @@
</xsl:otherwise>
</xsl:choose>
</xsl:otherwise>
</xsl:choose>
- </xsl:template><xsl:template match="*[local-name()='table']/*[local-name() = 'name']"/><xsl:template match="*[local-name()='table']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name()='table']/*[local-name() = 'name']">
<xsl:param name="continued"/>
<xsl:if test="normalize-space() != ''">
<fo:block xsl:use-attribute-sets="table-name-style">
+
-
<xsl:choose>
<xsl:when test="$continued = 'true'">
- <!-- <xsl:if test="$namespace = 'bsi'"></xsl:if> -->
</xsl:when>
<xsl:otherwise>
<xsl:apply-templates/>
</xsl:otherwise>
@@ -1751,17 +1981,10 @@
</xsl:when>
<xsl:otherwise>
<xsl:for-each select="xalan:nodeset($table)/*/tr">
<xsl:variable name="td_text">
<xsl:apply-templates select="td[$curr-col]" mode="td_text"/>
-
- <!-- <xsl:if test="$namespace = 'bipm'">
- <xsl:for-each select="*[local-name()='td'][$curr-col]//*[local-name()='math']">
- <word><xsl:value-of select="normalize-space(.)"/></word>
- </xsl:for-each>
- </xsl:if> -->
-
</xsl:variable>
<xsl:variable name="words">
<xsl:variable name="string_with_added_zerospaces">
<xsl:call-template name="add-zero-spaces-java">
<xsl:with-param name="text" select="$td_text"/>
@@ -1794,11 +2017,10 @@
</xsl:for-each>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
-
<column>
<xsl:for-each select="xalan:nodeset($widths)//width">
<xsl:sort select="." data-type="number" order="descending"/>
<xsl:if test="position()=1">
@@ -1830,11 +2052,10 @@
<xsl:variable name="math_text" select="normalize-space(xalan:nodeset($mathml))"/>
<xsl:value-of select="translate($math_text, ' ', '#')"/><!-- mathml images as one 'word' without spaces -->
</xsl:template><xsl:template match="*[local-name()='table2']"/><xsl:template match="*[local-name()='thead']"/><xsl:template match="*[local-name()='thead']" mode="process">
<xsl:param name="cols-count"/>
- <!-- font-weight="bold" -->
<fo:table-header>
<xsl:apply-templates/>
</fo:table-header>
@@ -1842,17 +2063,16 @@
<xsl:param name="cols-count"/>
<!-- row for title -->
<fo:table-row>
<fo:table-cell number-columns-spanned="{$cols-count}" border-left="1.5pt solid white" border-right="1.5pt solid white" border-top="1.5pt solid white" border-bottom="1.5pt solid black">
- <xsl:apply-templates select="ancestor::*[local-name()='table']/*[local-name()='name']" mode="presentation">
+ <xsl:apply-templates select="ancestor::*[local-name()='table']/*[local-name()='name']">
<xsl:with-param name="continued">true</xsl:with-param>
</xsl:apply-templates>
-
</fo:table-cell>
</fo:table-row>
</xsl:template><xsl:template match="*[local-name()='thead']" mode="process_tbody">
<fo:table-body>
<xsl:apply-templates/>
@@ -1864,68 +2084,10 @@
<xsl:if test="../*[local-name()='tfoot']">
<fo:table-footer>
<xsl:apply-templates select="../*[local-name()='tfoot']" mode="process"/>
</fo:table-footer>
</xsl:if>
- </xsl:template><xsl:template name="insertTableFooter2">
- <xsl:param name="cols-count"/>
- <xsl:variable name="isNoteOrFnExist" select="../*[local-name()='note'] or ..//*[local-name()='fn'][local-name(..) != 'name']"/>
- <xsl:if test="../*[local-name()='tfoot'] or $isNoteOrFnExist = 'true'">
-
- <fo:table-footer>
-
- <xsl:apply-templates select="../*[local-name()='tfoot']" mode="process"/>
-
- <!-- if there are note(s) or fn(s) then create footer row -->
- <xsl:if test="$isNoteOrFnExist = 'true'">
-
-
-
- <fo:table-row>
- <fo:table-cell border="solid black 1pt" padding-left="1mm" padding-right="1mm" padding-top="1mm" number-columns-spanned="{$cols-count}">
-
-
-
- <!-- fn will be processed inside 'note' processing -->
-
-
-
-
-
-
- <!-- except gb -->
-
- <xsl:apply-templates select="../*[local-name()='note']" mode="process"/>
-
-
- <!-- show Note under table in preface (ex. abstract) sections -->
- <!-- empty, because notes show at page side in main sections -->
- <!-- <xsl:if test="$namespace = 'bipm'">
- <xsl:choose>
- <xsl:when test="ancestor::*[local-name()='preface']">
- <xsl:apply-templates select="../*[local-name()='note']" mode="process"/>
- </xsl:when>
- <xsl:otherwise>
- <fo:block/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:if> -->
-
-
- <!-- horizontal row separator -->
-
-
- <!-- fn processing -->
- <xsl:call-template name="fn_display"/>
-
- </fo:table-cell>
- </fo:table-row>
-
- </xsl:if>
- </fo:table-footer>
-
- </xsl:if>
</xsl:template><xsl:template name="insertTableFooterInSeparateTable">
<xsl:param name="table_attributes"/>
<xsl:param name="colwidths"/>
<xsl:param name="colgroup"/>
@@ -1947,21 +2109,22 @@
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<fo:table keep-with-previous="always">
- <xsl:for-each select="xalan:nodeset($table_attributes)/attribute">
+ <xsl:for-each select="xalan:nodeset($table_attributes)/table_attributes/@*">
+ <xsl:variable name="name" select="local-name()"/>
<xsl:choose>
- <xsl:when test="@name = 'border-top'">
- <xsl:attribute name="{@name}">0pt solid black</xsl:attribute>
+ <xsl:when test="$name = 'border-top'">
+ <xsl:attribute name="{$name}">0pt solid black</xsl:attribute>
</xsl:when>
- <xsl:when test="@name = 'border'">
- <xsl:attribute name="{@name}"><xsl:value-of select="."/></xsl:attribute>
+ <xsl:when test="$name = 'border'">
+ <xsl:attribute name="{$name}"><xsl:value-of select="."/></xsl:attribute>
<xsl:attribute name="border-top">0pt solid black</xsl:attribute>
</xsl:when>
<xsl:otherwise>
- <xsl:attribute name="{@name}"><xsl:value-of select="."/></xsl:attribute>
+ <xsl:attribute name="{$name}"><xsl:value-of select="."/></xsl:attribute>
</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
@@ -1986,54 +2149,38 @@
</xsl:otherwise>
</xsl:choose>
<fo:table-body>
<fo:table-row>
- <fo:table-cell border="solid black 1pt" padding-left="1mm" padding-right="1mm" padding-top="1mm" number-columns-spanned="{$cols-count}">
+ <fo:table-cell xsl:use-attribute-sets="table-footer-cell-style" number-columns-spanned="{$cols-count}">
+
<!-- fn will be processed inside 'note' processing -->
-
-
-
<!-- for BSI (not PAS) display Notes before footnotes -->
- <!-- except gb -->
+ <!-- except gb and bsi -->
- <xsl:apply-templates select="../*[local-name()='note']" mode="process"/>
+ <xsl:apply-templates select="../*[local-name()='note']" mode="process"/>
+
- <!-- <xsl:if test="$namespace = 'bipm'">
- <xsl:choose>
- <xsl:when test="ancestor::*[local-name()='preface']">
- show Note under table in preface (ex. abstract) sections
- <xsl:apply-templates select="../*[local-name()='note']" mode="process"/>
- </xsl:when>
- <xsl:otherwise>
- empty, because notes show at page side in main sections
- <fo:block/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:if> -->
-
-
<!-- horizontal row separator -->
<!-- fn processing -->
- <xsl:call-template name="fn_display"/>
+ <xsl:call-template name="table_fn_display"/>
-
<!-- for PAS display Notes after footnotes -->
</fo:table-cell>
</fo:table-row>
@@ -2070,105 +2217,88 @@
<fo:table-body>
<xsl:apply-templates/>
- <!-- <xsl:apply-templates select="../*[local-name()='tfoot']" mode="process"/> -->
-
+
</fo:table-body>
- </xsl:template><xsl:template match="*[local-name()='table']/*[local-name()='name']/text()[1]" priority="2" mode="presentation_name">
- <xsl:choose>
- <xsl:when test="substring-after(., '—') != ''">
- <xsl:text>—</xsl:text><xsl:value-of select="substring-after(., '—')"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:value-of select="."/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:template><xsl:template match="*[local-name()='table']/*[local-name()='name']" mode="presentation_name">
- <xsl:apply-templates mode="presentation_name"/>
- </xsl:template><xsl:template match="*[local-name()='table']/*[local-name()='name']/node()" mode="presentation_name">
- <xsl:apply-templates select="."/>
- </xsl:template><xsl:template match="*[local-name()='tr']">
- <xsl:variable name="parent-name" select="local-name(..)"/>
- <!-- <xsl:variable name="namespace" select="substring-before(name(/*), '-')"/> -->
- <fo:table-row min-height="4mm">
- <xsl:if test="$parent-name = 'thead'">
- <xsl:attribute name="font-weight">bold</xsl:attribute>
-
-
-
-
-
-
-
-
- </xsl:if>
- <xsl:if test="$parent-name = 'tfoot'">
-
-
-
- </xsl:if>
-
-
-
-
-
-
-
-
-
-
- <!-- <xsl:if test="$namespace = 'bipm'">
- <xsl:attribute name="height">8mm</xsl:attribute>
- </xsl:if> -->
-
+ </xsl:template><xsl:template match="*[local-name()='thead']/*[local-name()='tr']" priority="2">
+ <fo:table-row xsl:use-attribute-sets="table-header-row-style">
+
+
+
+
+
+
+
+ <xsl:call-template name="setTableRowAttributes"/>
+
<xsl:apply-templates/>
</fo:table-row>
- </xsl:template><xsl:template match="*[local-name()='th']">
- <fo:table-cell text-align="{@align}" font-weight="bold" border="solid black 1pt" padding-left="1mm" display-align="center">
- <xsl:attribute name="text-align">
- <xsl:choose>
- <xsl:when test="@align">
- <xsl:call-template name="setAlignment"/>
- <!-- <xsl:value-of select="@align"/> -->
- </xsl:when>
- <xsl:otherwise>center</xsl:otherwise>
- </xsl:choose>
- </xsl:attribute>
+ </xsl:template><xsl:template match="*[local-name()='tfoot']/*[local-name()='tr']" priority="2">
+ <fo:table-row xsl:use-attribute-sets="table-footer-row-style">
+ <xsl:call-template name="setTableRowAttributes"/>
+ <xsl:apply-templates/>
+ </fo:table-row>
+ </xsl:template><xsl:template match="*[local-name()='tr']">
+ <fo:table-row xsl:use-attribute-sets="table-body-row-style">
+
+
+
+ <xsl:call-template name="setTableRowAttributes"/>
+ <xsl:apply-templates/>
+ </fo:table-row>
+ </xsl:template><xsl:template name="setTableRowAttributes">
+
+
+
+
+
+
+
+
+ </xsl:template><xsl:template match="*[local-name()='th']">
+ <fo:table-cell xsl:use-attribute-sets="table-header-cell-style"> <!-- text-align="{@align}" -->
+ <xsl:call-template name="setTextAlignment">
+ <xsl:with-param name="default">center</xsl:with-param>
+ </xsl:call-template>
+
-
<xsl:if test="$lang = 'ar'">
<xsl:attribute name="padding-right">1mm</xsl:attribute>
</xsl:if>
- <xsl:if test="@colspan">
- <xsl:attribute name="number-columns-spanned">
- <xsl:value-of select="@colspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:if test="@rowspan">
- <xsl:attribute name="number-rows-spanned">
- <xsl:value-of select="@rowspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:call-template name="display-align"/>
+
+ <xsl:call-template name="setTableCellAttributes"/>
+
<fo:block>
<xsl:apply-templates/>
</fo:block>
</fo:table-cell>
+ </xsl:template><xsl:template name="setTableCellAttributes">
+ <xsl:if test="@colspan">
+ <xsl:attribute name="number-columns-spanned">
+ <xsl:value-of select="@colspan"/>
+ </xsl:attribute>
+ </xsl:if>
+ <xsl:if test="@rowspan">
+ <xsl:attribute name="number-rows-spanned">
+ <xsl:value-of select="@rowspan"/>
+ </xsl:attribute>
+ </xsl:if>
+ <xsl:call-template name="display-align"/>
</xsl:template><xsl:template name="display-align">
<xsl:if test="@valign">
<xsl:attribute name="display-align">
<xsl:choose>
<xsl:when test="@valign = 'top'">before</xsl:when>
@@ -2177,86 +2307,75 @@
<xsl:otherwise>before</xsl:otherwise>
</xsl:choose>
</xsl:attribute>
</xsl:if>
</xsl:template><xsl:template match="*[local-name()='td']">
- <fo:table-cell text-align="{@align}" display-align="center" border="solid black 1pt" padding-left="1mm">
- <xsl:attribute name="text-align">
- <xsl:choose>
- <xsl:when test="@align">
- <xsl:call-template name="setAlignment"/>
- <!-- <xsl:value-of select="@align"/> -->
- </xsl:when>
- <xsl:otherwise>left</xsl:otherwise>
- </xsl:choose>
- </xsl:attribute>
+ <fo:table-cell xsl:use-attribute-sets="table-cell-style"> <!-- text-align="{@align}" -->
+ <xsl:call-template name="setTextAlignment">
+ <xsl:with-param name="default">left</xsl:with-param>
+ </xsl:call-template>
+
<xsl:if test="$lang = 'ar'">
<xsl:attribute name="padding-right">1mm</xsl:attribute>
</xsl:if>
+ <!-- bsi -->
+
- <xsl:if test=".//*[local-name() = 'table']">
+
+ <xsl:if test=".//*[local-name() = 'table']"> <!-- if there is nested table -->
<xsl:attribute name="padding-right">1mm</xsl:attribute>
</xsl:if>
- <xsl:if test="@colspan">
- <xsl:attribute name="number-columns-spanned">
- <xsl:value-of select="@colspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:if test="@rowspan">
- <xsl:attribute name="number-rows-spanned">
- <xsl:value-of select="@rowspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:call-template name="display-align"/>
+
+ <xsl:call-template name="setTableCellAttributes"/>
+
<fo:block>
-
+
+
+
<xsl:apply-templates/>
</fo:block>
</fo:table-cell>
</xsl:template><xsl:template match="*[local-name()='table']/*[local-name()='note']" priority="2"/><xsl:template match="*[local-name()='table']/*[local-name()='note']" mode="process">
+
+ <fo:block xsl:use-attribute-sets="table-note-style">
+
+
+
+
-
- <fo:block font-size="10pt" margin-bottom="12pt">
+ <!-- Table's note name (NOTE, for example) -->
+ <fo:inline xsl:use-attribute-sets="table-note-name-style">
-
- <!-- Table's note name (NOTE, for example) -->
-
- <fo:inline padding-right="2mm" xsl:use-attribute-sets="table-note-name-style">
+ <xsl:apply-templates select="*[local-name() = 'name']"/>
-
-
-
-
- <xsl:apply-templates select="*[local-name() = 'name']" mode="presentation"/>
-
- </fo:inline>
-
-
-
- <xsl:apply-templates mode="process"/>
- </fo:block>
+ </fo:inline>
+
+
+
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]" mode="process"/>
+ </fo:block>
</xsl:template><xsl:template match="*[local-name()='table']/*[local-name()='note']/*[local-name()='name']" mode="process"/><xsl:template match="*[local-name()='table']/*[local-name()='note']/*[local-name()='p']" mode="process">
<xsl:apply-templates/>
</xsl:template><xsl:template match="*[local-name() = 'fn'][not(ancestor::*[(local-name() = 'table' or local-name() = 'figure') and not(ancestor::*[local-name() = 'name'])])]" priority="2" name="fn">
@@ -2332,13 +2451,12 @@
<xsl:when test="$p_fn//fn[@gen_id = $gen_id] or normalize-space(@skip_footnote_body) = 'false'">
<fo:footnote xsl:use-attribute-sets="fn-style">
<xsl:copy-of select="$footnote_inline"/>
<fo:footnote-body>
- <fo:block-container text-indent="0" start-indent="0">
+ <fo:block-container xsl:use-attribute-sets="fn-container-body-style">
-
<fo:block xsl:use-attribute-sets="fn-body-style">
<fo:inline id="{$ref_id}" xsl:use-attribute-sets="fn-body-num-style">
@@ -2352,48 +2470,41 @@
</xsl:when>
<xsl:otherwise>
<xsl:copy-of select="$footnote_inline"/>
</xsl:otherwise>
</xsl:choose>
- </xsl:template><xsl:template name="fn_display">
+ </xsl:template><xsl:template name="table_fn_display">
<xsl:variable name="references">
<xsl:for-each select="..//*[local-name()='fn'][local-name(..) != 'name']">
<xsl:call-template name="create_fn"/>
</xsl:for-each>
</xsl:variable>
<xsl:for-each select="xalan:nodeset($references)//fn">
<xsl:variable name="reference" select="@reference"/>
<xsl:if test="not(preceding-sibling::*[@reference = $reference])"> <!-- only unique reference puts in note-->
- <fo:block margin-bottom="12pt">
+ <fo:block xsl:use-attribute-sets="table-fn-style">
-
-
-
-
- <fo:inline font-size="80%" padding-right="5mm" id="{@id}">
+ <fo:inline id="{@id}" xsl:use-attribute-sets="table-fn-number-style">
- <xsl:attribute name="vertical-align">super</xsl:attribute>
+ <xsl:value-of select="@reference"/>
- <xsl:value-of select="@reference"/>
</fo:inline>
- <fo:inline>
-
- <!-- <xsl:apply-templates /> -->
+ <fo:inline xsl:use-attribute-sets="table-fn-body-style">
<xsl:copy-of select="./node()"/>
</fo:inline>
</fo:block>
</xsl:if>
</xsl:for-each>
@@ -2401,81 +2512,73 @@
<fn reference="{@reference}" id="{@reference}_{ancestor::*[@id][1]/@id}">
<xsl:apply-templates/>
</fn>
- </xsl:template><xsl:template name="fn_name_display">
- <!-- <xsl:variable name="references">
- <xsl:for-each select="*[local-name()='name']//*[local-name()='fn']">
- <fn reference="{@reference}" id="{@reference}_{ancestor::*[@id][1]/@id}">
- <xsl:apply-templates />
- </fn>
- </xsl:for-each>
- </xsl:variable>
- $references=<xsl:copy-of select="$references"/> -->
+ </xsl:template><xsl:template name="table_name_fn_display">
<xsl:for-each select="*[local-name()='name']//*[local-name()='fn']">
<xsl:variable name="reference" select="@reference"/>
<fo:block id="{@reference}_{ancestor::*[@id][1]/@id}"><xsl:value-of select="@reference"/></fo:block>
<fo:block margin-bottom="12pt">
<xsl:apply-templates/>
</fo:block>
</xsl:for-each>
</xsl:template><xsl:template name="fn_display_figure">
- <xsl:variable name="key_iso">
- <!-- and (not(@class) or @class !='pseudocode') -->
- </xsl:variable>
+
<xsl:variable name="references">
<xsl:for-each select=".//*[local-name()='fn'][not(parent::*[local-name()='name'])]">
<fn reference="{@reference}" id="{@reference}_{ancestor::*[@id][1]/@id}">
<xsl:apply-templates/>
</fn>
</xsl:for-each>
</xsl:variable>
+
+ <xsl:if test="xalan:nodeset($references)//fn">
- <!-- current hierarchy is 'figure' element -->
- <xsl:variable name="following_dl_colwidths">
- <xsl:if test="*[local-name() = 'dl']"><!-- if there is a 'dl', then set the same columns width as for 'dl' -->
- <xsl:variable name="html-table">
- <xsl:variable name="doc_ns">
+ <xsl:variable name="key_iso">
+
+ </xsl:variable>
+
+ <!-- current hierarchy is 'figure' element -->
+ <xsl:variable name="following_dl_colwidths">
+ <xsl:if test="*[local-name() = 'dl']"><!-- if there is a 'dl', then set the same columns width as for 'dl' -->
+ <xsl:variable name="html-table">
+ <xsl:variable name="doc_ns">
+
+ </xsl:variable>
+ <xsl:variable name="ns">
+ <xsl:choose>
+ <xsl:when test="normalize-space($doc_ns) != ''">
+ <xsl:value-of select="normalize-space($doc_ns)"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="substring-before(name(/*), '-')"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
- </xsl:variable>
- <xsl:variable name="ns">
- <xsl:choose>
- <xsl:when test="normalize-space($doc_ns) != ''">
- <xsl:value-of select="normalize-space($doc_ns)"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:value-of select="substring-before(name(/*), '-')"/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
- <!-- <xsl:variable name="ns" select="substring-before(name(/*), '-')"/> -->
- <!-- <xsl:element name="{$ns}:table"> -->
<xsl:for-each select="*[local-name() = 'dl'][1]">
<tbody>
<xsl:apply-templates mode="dl"/>
</tbody>
</xsl:for-each>
- <!-- </xsl:element> -->
- </xsl:variable>
-
- <xsl:call-template name="calculate-column-widths">
- <xsl:with-param name="cols-count" select="2"/>
- <xsl:with-param name="table" select="$html-table"/>
- </xsl:call-template>
-
- </xsl:if>
- </xsl:variable>
-
-
- <xsl:variable name="maxlength_dt">
- <xsl:for-each select="*[local-name() = 'dl'][1]">
- <xsl:call-template name="getMaxLength_dt"/>
- </xsl:for-each>
- </xsl:variable>
-
- <xsl:if test="xalan:nodeset($references)//fn">
+ </xsl:variable>
+
+ <xsl:call-template name="calculate-column-widths">
+ <xsl:with-param name="cols-count" select="2"/>
+ <xsl:with-param name="table" select="$html-table"/>
+ </xsl:call-template>
+
+ </xsl:if>
+ </xsl:variable>
+
+ <xsl:variable name="maxlength_dt">
+ <xsl:for-each select="*[local-name() = 'dl'][1]">
+ <xsl:call-template name="getMaxLength_dt"/>
+ </xsl:for-each>
+ </xsl:variable>
+
<fo:block>
<fo:table width="95%" table-layout="fixed">
<xsl:if test="normalize-space($key_iso) = 'true'">
<xsl:attribute name="font-size">10pt</xsl:attribute>
@@ -2498,24 +2601,22 @@
<xsl:variable name="reference" select="@reference"/>
<xsl:if test="not(preceding-sibling::*[@reference = $reference])"> <!-- only unique reference puts in note-->
<fo:table-row>
<fo:table-cell>
<fo:block>
- <fo:inline font-size="80%" padding-right="5mm" vertical-align="super" id="{@id}">
-
+ <fo:inline id="{@id}" xsl:use-attribute-sets="figure-fn-number-style">
<xsl:value-of select="@reference"/>
</fo:inline>
</fo:block>
</fo:table-cell>
<fo:table-cell>
- <fo:block text-align="justify" margin-bottom="12pt">
-
+ <fo:block xsl:use-attribute-sets="figure-fn-body-style">
<xsl:if test="normalize-space($key_iso) = 'true'">
- <xsl:attribute name="margin-bottom">0</xsl:attribute>
+
+ <xsl:attribute name="margin-bottom">0</xsl:attribute>
+
</xsl:if>
-
- <!-- <xsl:apply-templates /> -->
<xsl:copy-of select="./node()"/>
</fo:block>
</fo:table-cell>
</fo:table-row>
</xsl:if>
@@ -2524,22 +2625,16 @@
</fo:table>
</fo:block>
</xsl:if>
</xsl:template><xsl:template match="*[local-name()='fn']">
- <!-- <xsl:variable name="namespace" select="substring-before(name(/*), '-')"/> -->
- <fo:inline font-size="80%" keep-with-previous.within-line="always">
+ <fo:inline xsl:use-attribute-sets="fn-reference-style">
+
-
-
-
-
-
-
<fo:basic-link internal-destination="{@reference}_{ancestor::*[@id][1]/@id}" fox:alt-text="{@reference}"> <!-- @reference | ancestor::*[local-name()='clause'][1]/@id-->
<xsl:value-of select="@reference"/>
@@ -2555,15 +2650,15 @@
</xsl:template><xsl:template match="*[local-name()='dl']">
<xsl:variable name="isAdded" select="@added"/>
<xsl:variable name="isDeleted" select="@deleted"/>
<fo:block-container>
- <xsl:if test="not(ancestor::*[local-name() = 'quote'])">
- <xsl:attribute name="margin-left">0mm</xsl:attribute>
- </xsl:if>
+ <xsl:if test="not(ancestor::*[local-name() = 'quote'])">
+ <xsl:attribute name="margin-left">0mm</xsl:attribute>
+ </xsl:if>
+
-
<xsl:if test="parent::*[local-name() = 'note']">
<xsl:attribute name="margin-left">
<xsl:choose>
<xsl:when test="not(ancestor::*[local-name() = 'table'])"><xsl:value-of select="$note-body-indent"/></xsl:when>
<xsl:otherwise><xsl:value-of select="$note-body-indent-table"/></xsl:otherwise>
@@ -2575,39 +2670,38 @@
<xsl:call-template name="setTrackChangesStyles">
<xsl:with-param name="isAdded" select="$isAdded"/>
<xsl:with-param name="isDeleted" select="$isDeleted"/>
</xsl:call-template>
- <fo:block-container>
+ <fo:block-container margin-left="0mm">
+
- <xsl:attribute name="margin-left">0mm</xsl:attribute>
- <xsl:attribute name="margin-right">0mm</xsl:attribute>
+ <xsl:attribute name="margin-right">0mm</xsl:attribute>
+
-
<xsl:variable name="parent" select="local-name(..)"/>
<xsl:variable name="key_iso">
<!-- and (not(../@class) or ../@class !='pseudocode') -->
</xsl:variable>
<xsl:choose>
<xsl:when test="$parent = 'formula' and count(*[local-name()='dt']) = 1"> <!-- only one component -->
-
- <fo:block margin-bottom="12pt" text-align="left">
-
- <xsl:variable name="title-where">
- <xsl:call-template name="getLocalizedString">
- <xsl:with-param name="key">where</xsl:with-param>
- </xsl:call-template>
- </xsl:variable>
- <xsl:value-of select="$title-where"/><xsl:text> </xsl:text>
- <xsl:apply-templates select="*[local-name()='dt']/*"/>
- <xsl:text/>
- <xsl:apply-templates select="*[local-name()='dd']/*" mode="inline"/>
- </fo:block>
-
+ <fo:block margin-bottom="12pt" text-align="left">
+
+ <xsl:variable name="title-where">
+ <xsl:call-template name="getLocalizedString">
+ <xsl:with-param name="key">where</xsl:with-param>
+ </xsl:call-template>
+ </xsl:variable>
+ <xsl:value-of select="$title-where"/><xsl:text> </xsl:text>
+ <xsl:apply-templates select="*[local-name()='dt']/*"/>
+ <xsl:text/>
+ <xsl:apply-templates select="*[local-name()='dd']/*" mode="inline"/>
+ </fo:block>
+
</xsl:when>
<xsl:when test="$parent = 'formula'"> <!-- a few components -->
<fo:block margin-bottom="12pt" text-align="left">
@@ -2650,13 +2744,11 @@
<fo:table width="95%" table-layout="fixed">
<xsl:choose>
- <xsl:when test="normalize-space($key_iso) = 'true' and $parent = 'formula'">
- <!-- <xsl:attribute name="font-size">11pt</xsl:attribute> -->
- </xsl:when>
+ <xsl:when test="normalize-space($key_iso) = 'true' and $parent = 'formula'"/>
<xsl:when test="normalize-space($key_iso) = 'true'">
<xsl:attribute name="font-size">10pt</xsl:attribute>
</xsl:when>
</xsl:choose>
@@ -2673,16 +2765,13 @@
<xsl:otherwise>
<xsl:value-of select="substring-before(name(/*), '-')"/>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
- <!-- <xsl:variable name="ns" select="substring-before(name(/*), '-')"/> -->
- <!-- <xsl:element name="{$ns}:table"> -->
- <tbody>
- <xsl:apply-templates mode="dl"/>
- </tbody>
- <!-- </xsl:element> -->
+ <tbody>
+ <xsl:apply-templates mode="dl"/>
+ </tbody>
</xsl:variable>
<!-- html-table<xsl:copy-of select="$html-table"/> -->
<xsl:variable name="colwidths">
<xsl:call-template name="calculate-column-widths">
<xsl:with-param name="cols-count" select="2"/>
@@ -2758,12 +2847,10 @@
</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</xsl:otherwise>
</xsl:choose>
- <!-- <fo:table-column column-width="15%"/>
- <fo:table-column column-width="85%"/> -->
</xsl:otherwise>
</xsl:choose>
</xsl:template><xsl:template name="getMaxLength_dt">
<xsl:variable name="lengths">
<xsl:for-each select="*[local-name()='dt']">
@@ -2774,16 +2861,10 @@
</xsl:variable>
<length><xsl:value-of select="string-length(normalize-space(.)) + string-length($attributes)"/></length>
</xsl:for-each>
</xsl:variable>
<xsl:variable name="maxLength">
- <!-- <xsl:for-each select="*[local-name()='dt']">
- <xsl:sort select="string-length(normalize-space(.))" data-type="number" order="descending"/>
- <xsl:if test="position() = 1">
- <xsl:value-of select="string-length(normalize-space(.))"/>
- </xsl:if>
- </xsl:for-each> -->
<xsl:for-each select="xalan:nodeset($lengths)/length">
<xsl:sort select="." data-type="number" order="descending"/>
<xsl:if test="position() = 1">
<xsl:value-of select="."/>
</xsl:if>
@@ -2805,98 +2886,57 @@
<fo:table-cell>
<fo:block margin-top="6pt">
<xsl:if test="normalize-space($key_iso) = 'true'">
<xsl:attribute name="margin-top">0</xsl:attribute>
</xsl:if>
- <xsl:apply-templates select="*[local-name() = 'name']" mode="presentation"/>
+ <xsl:apply-templates select="*[local-name() = 'name']"/>
</fo:block>
</fo:table-cell>
<fo:table-cell>
<fo:block>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
</fo:table-cell>
</fo:table-row>
</xsl:template><xsl:template match="*[local-name()='dt']" mode="dl">
<tr>
<td>
<xsl:apply-templates/>
</td>
<td>
-
- <xsl:apply-templates select="following-sibling::*[local-name()='dd'][1]" mode="process"/>
-
+ <xsl:apply-templates select="following-sibling::*[local-name()='dd'][1]" mode="process"/>
+
</td>
</tr>
</xsl:template><xsl:template match="*[local-name()='dt']">
<xsl:param name="key_iso"/>
- <fo:table-row>
-
-
+ <fo:table-row xsl:use-attribute-sets="dt-row-style">
<fo:table-cell>
- <fo:block margin-top="6pt">
+ <fo:block xsl:use-attribute-sets="dt-style">
<xsl:copy-of select="@id"/>
-
<xsl:if test="normalize-space($key_iso) = 'true'">
<xsl:attribute name="margin-top">0</xsl:attribute>
-
</xsl:if>
- <xsl:attribute name="margin-left">7mm</xsl:attribute>
-
-
-
-
-
<xsl:apply-templates/>
- <!-- <xsl:if test="$namespace = 'gb'">
- <xsl:if test="ancestor::*[local-name()='formula']">
- <xsl:text>—</xsl:text>
- </xsl:if>
- </xsl:if> -->
</fo:block>
</fo:table-cell>
<fo:table-cell>
<fo:block>
- <!-- <xsl:if test="$namespace = 'nist-cswp' or $namespace = 'nist-sp'">
- <xsl:if test="local-name(*[1]) != 'stem'">
- <xsl:apply-templates select="following-sibling::*[local-name()='dd'][1]" mode="process"/>
- </xsl:if>
- </xsl:if> -->
-
- <xsl:apply-templates select="following-sibling::*[local-name()='dd'][1]" mode="process"/>
-
+
+ <xsl:apply-templates select="following-sibling::*[local-name()='dd'][1]" mode="process"/>
</fo:block>
</fo:table-cell>
</fo:table-row>
- <!-- <xsl:if test="$namespace = 'nist-cswp' or $namespace = 'nist-sp'">
- <xsl:if test="local-name(*[1]) = 'stem'">
- <fo:table-row>
- <fo:table-cell>
- <fo:block margin-top="6pt">
- <xsl:if test="normalize-space($key_iso) = 'true'">
- <xsl:attribute name="margin-top">0</xsl:attribute>
- </xsl:if>
- <xsl:text> </xsl:text>
- </fo:block>
- </fo:table-cell>
- <fo:table-cell>
- <fo:block>
- <xsl:apply-templates select="following-sibling::*[local-name()='dd'][1]" mode="process"/>
- </fo:block>
- </fo:table-cell>
- </fo:table-row>
- </xsl:if>
- </xsl:if> -->
</xsl:template><xsl:template match="*[local-name()='dd']" mode="dl"/><xsl:template match="*[local-name()='dd']" mode="dl_process">
<xsl:apply-templates/>
</xsl:template><xsl:template match="*[local-name()='dd']"/><xsl:template match="*[local-name()='dd']" mode="process">
<xsl:apply-templates select="@language"/>
<xsl:apply-templates/>
@@ -2921,10 +2961,11 @@
<fo:inline font-size="80%" vertical-align="sub">
<xsl:apply-templates/>
</fo:inline>
</xsl:template><xsl:template match="*[local-name()='tt']">
<fo:inline xsl:use-attribute-sets="tt-style">
+
<xsl:variable name="_font-size">
10
@@ -2957,19 +2998,25 @@
</xsl:template><xsl:template match="*[local-name()='underline']">
<fo:inline text-decoration="underline">
<xsl:apply-templates/>
</fo:inline>
</xsl:template><xsl:template match="*[local-name()='add']">
+ <xsl:param name="skip">true</xsl:param>
<xsl:choose>
<xsl:when test="starts-with(., $ace_tag)"> <!-- examples: ace-tag_A1_start, ace-tag_A2_end, C1_start, AC_start -->
- <fo:inline>
- <xsl:call-template name="insertTag">
- <xsl:with-param name="type" select="substring-after(substring-after(., $ace_tag), '_')"/> <!-- start or end -->
- <xsl:with-param name="kind" select="substring(substring-before(substring-after(., $ace_tag), '_'), 1, 1)"/> <!-- A or C -->
- <xsl:with-param name="value" select="substring(substring-before(substring-after(., $ace_tag), '_'), 2)"/> <!-- 1, 2, C -->
- </xsl:call-template>
- </fo:inline>
+ <xsl:choose>
+ <xsl:when test="$skip = 'true' and ((local-name(../..) = 'note' and not(preceding-sibling::node())) or (local-name(..) = 'title' and preceding-sibling::node()[1][local-name() = 'tab'])) and ../node()[last()][local-name() = 'add'][starts-with(text(), $ace_tag)]"><!-- start tag displayed in template name="note" and title --></xsl:when>
+ <xsl:otherwise>
+ <fo:inline>
+ <xsl:call-template name="insertTag">
+ <xsl:with-param name="type" select="substring-after(substring-after(., $ace_tag), '_')"/> <!-- start or end -->
+ <xsl:with-param name="kind" select="substring(substring-before(substring-after(., $ace_tag), '_'), 1, 1)"/> <!-- A or C -->
+ <xsl:with-param name="value" select="substring(substring-before(substring-after(., $ace_tag), '_'), 2)"/> <!-- 1, 2, C -->
+ </xsl:call-template>
+ </fo:inline>
+ </xsl:otherwise>
+ </xsl:choose>
</xsl:when>
<xsl:when test="@amendment">
<fo:inline>
<xsl:call-template name="insertTag">
<xsl:with-param name="kind">A</xsl:with-param>
@@ -3008,12 +3055,10 @@
<xsl:param name="kind"/>
<xsl:param name="value"/>
<xsl:variable name="add_width" select="string-length($value) * 20"/>
<xsl:variable name="maxwidth" select="60 + $add_width"/>
<fo:instream-foreign-object fox:alt-text="OpeningTag" baseline-shift="-20%"><!-- alignment-baseline="middle" -->
- <!-- <xsl:attribute name="width">7mm</xsl:attribute>
- <xsl:attribute name="content-height">100%</xsl:attribute> -->
<xsl:attribute name="height">5mm</xsl:attribute>
<xsl:attribute name="content-width">100%</xsl:attribute>
<xsl:attribute name="content-width">scale-down-to-fit</xsl:attribute>
<xsl:attribute name="scaling">uniform</xsl:attribute>
<svg xmlns="http://www.w3.org/2000/svg" width="{$maxwidth + 32}" height="80">
@@ -3227,18 +3272,10 @@
<xsl:apply-templates select="xalan:nodeset($simple-table-colspan)" mode="simple-table-rowspan"/>
</xsl:variable>
<xsl:copy-of select="xalan:nodeset($simple-table-rowspan)"/>
- <!-- <xsl:choose>
- <xsl:when test="current()//*[local-name()='th'][@colspan] or current()//*[local-name()='td'][@colspan] ">
-
- </xsl:when>
- <xsl:otherwise>
- <xsl:copy-of select="current()"/>
- </xsl:otherwise>
- </xsl:choose> -->
</xsl:variable>
<xsl:copy-of select="$simple-table"/>
</xsl:template><xsl:template match="*[local-name()='thead'] | *[local-name()='tbody']" mode="simple-table-colspan">
<xsl:apply-templates mode="simple-table-colspan"/>
</xsl:template><xsl:template match="*[local-name()='fn']" mode="simple-table-colspan"/><xsl:template match="*[local-name()='th'] | *[local-name()='td']" mode="simple-table-colspan">
@@ -3353,23 +3390,19 @@
<xsl:param name="str"/>
<xsl:variable name="str2" select="translate($str, '-', ' ')"/>
<xsl:choose>
<xsl:when test="contains($str2, ' ')">
<xsl:variable name="substr" select="substring-before($str2, ' ')"/>
- <!-- <xsl:value-of select="translate(substring($substr, 1, 1), $lower, $upper)"/>
- <xsl:value-of select="substring($substr, 2)"/> -->
<xsl:call-template name="capitalize">
<xsl:with-param name="str" select="$substr"/>
</xsl:call-template>
<xsl:text> </xsl:text>
<xsl:call-template name="capitalizeWords">
<xsl:with-param name="str" select="substring-after($str2, ' ')"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
- <!-- <xsl:value-of select="translate(substring($str2, 1, 1), $lower, $upper)"/>
- <xsl:value-of select="substring($str2, 2)"/> -->
<xsl:call-template name="capitalize">
<xsl:with-param name="str" select="$str2"/>
</xsl:call-template>
</xsl:otherwise>
</xsl:choose>
@@ -3393,10 +3426,11 @@
<xsl:variable name="mathml">
<xsl:apply-templates select="." mode="mathml"/>
</xsl:variable>
<fo:instream-foreign-object fox:alt-text="Math">
+
<xsl:variable name="comment_text_following" select="following-sibling::node()[1][self::comment()]"/>
<xsl:variable name="comment_text_">
<xsl:choose>
@@ -3424,11 +3458,11 @@
<xsl:attribute name="fox:actual-text">
<xsl:value-of select="$mathml_content"/>
</xsl:attribute>
- <!-- <xsl:copy-of select="."/> -->
+
<xsl:copy-of select="xalan:nodeset($mathml)"/>
</fo:instream-foreign-object>
</fo:inline>
</xsl:template><xsl:template match="mathml:*" mode="mathml_actual_text">
<!-- <xsl:text>a+b</xsl:text> -->
@@ -3483,10 +3517,14 @@
</xsl:variable>
<fo:inline xsl:use-attribute-sets="link-style">
+
+
+
+
<xsl:choose>
<xsl:when test="$target_text = ''">
<xsl:apply-templates/>
</xsl:when>
<xsl:otherwise>
@@ -3540,11 +3578,10 @@
<xsl:if test="not(preceding-sibling::*[local-name() = 'p'])"><xsl:value-of select="$callout"/></xsl:if>
<xsl:apply-templates/>
</fo:inline>
</xsl:template><xsl:template match="*[local-name() = 'xref']">
<fo:basic-link internal-destination="{@target}" fox:alt-text="{@target}" xsl:use-attribute-sets="xref-style">
-
<xsl:apply-templates/>
</fo:basic-link>
</xsl:template><xsl:template match="*[local-name() = 'formula']" name="formula">
<fo:block-container margin-left="0mm">
<xsl:if test="parent::*[local-name() = 'note']">
@@ -3568,53 +3605,68 @@
</fo:inline>
</xsl:template><xsl:template match="*[local-name() = 'admitted']/*[local-name() = 'stem']">
<fo:inline>
<xsl:apply-templates/>
</fo:inline>
- </xsl:template><xsl:template match="*[local-name() = 'formula']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'formula']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'formula']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'formula']/*[local-name() = 'name']" mode="formula_number"> <!-- show by demand -->
<xsl:if test="normalize-space() != ''">
<xsl:text>(</xsl:text><xsl:apply-templates/><xsl:text>)</xsl:text>
</xsl:if>
</xsl:template><xsl:template match="*[local-name() = 'note']" name="note">
<fo:block-container id="{@id}" xsl:use-attribute-sets="note-style">
+
+
+
+
+
+
<fo:block-container margin-left="0mm">
+
+
-
-
-
-
- <fo:block>
+ <fo:block>
+
+
-
-
-
-
-
- <fo:inline xsl:use-attribute-sets="note-name-style">
- <xsl:apply-templates select="*[local-name() = 'name']" mode="presentation"/>
- </fo:inline>
- <xsl:apply-templates/>
- </fo:block>
-
-
+
+
+
+ <fo:inline xsl:use-attribute-sets="note-name-style">
+
+
+
+ <!-- if note contains only one element and first and last childs are `add` ace-tag, then move start ace-tag before NOTE's name-->
+ <xsl:if test="count(*[not(local-name() = 'name')]) = 1 and *[not(local-name() = 'name')]/node()[last()][local-name() = 'add'][starts-with(text(), $ace_tag)]">
+ <xsl:apply-templates select="*[not(local-name() = 'name')]/node()[1][local-name() = 'add'][starts-with(text(), $ace_tag)]">
+ <xsl:with-param name="skip">false</xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:if>
+
+ <xsl:apply-templates select="*[local-name() = 'name']"/>
+
+ </fo:inline>
+
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
+ </fo:block>
+
</fo:block-container>
</fo:block-container>
</xsl:template><xsl:template match="*[local-name() = 'note']/*[local-name() = 'p']">
<xsl:variable name="num"><xsl:number/></xsl:variable>
<xsl:choose>
- <xsl:when test="$num = 1">
+ <xsl:when test="$num = 1"> <!-- display first NOTE's paragraph in the same line with label NOTE -->
<fo:inline xsl:use-attribute-sets="note-p-style">
<xsl:apply-templates/>
</fo:inline>
</xsl:when>
<xsl:otherwise>
@@ -3625,16 +3677,20 @@
</xsl:choose>
</xsl:template><xsl:template match="*[local-name() = 'termnote']">
<fo:block id="{@id}" xsl:use-attribute-sets="termnote-style">
<fo:inline xsl:use-attribute-sets="termnote-name-style">
+
- <xsl:apply-templates select="*[local-name() = 'name']" mode="presentation"/>
+
+ <xsl:apply-templates select="*[local-name() = 'name']"/>
+
</fo:inline>
- <xsl:apply-templates/>
+
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'note']/*[local-name() = 'name'] | *[local-name() = 'termnote']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'note']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'note']/*[local-name() = 'name']">
<xsl:param name="sfx"/>
<xsl:variable name="suffix">
<xsl:choose>
<xsl:when test="$sfx != ''">
<xsl:value-of select="$sfx"/>
@@ -3647,11 +3703,11 @@
</xsl:variable>
<xsl:if test="normalize-space() != ''">
<xsl:apply-templates/>
<xsl:value-of select="$suffix"/>
</xsl:if>
- </xsl:template><xsl:template match="*[local-name() = 'termnote']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'termnote']/*[local-name() = 'name']">
<xsl:param name="sfx"/>
<xsl:variable name="suffix">
<xsl:choose>
<xsl:when test="$sfx != ''">
<xsl:value-of select="$sfx"/>
@@ -3672,29 +3728,27 @@
<!-- <xsl:message>'terms' <xsl:number/> processing...</xsl:message> -->
<fo:block id="{@id}">
<xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'term']">
- <!-- <xsl:message>'term' <xsl:number/> processing, name=<xsl:value-of select="iso:name"/>, preferred=<xsl:value-of select="iso:preferred"/>...</xsl:message> -->
<fo:block id="{@id}" xsl:use-attribute-sets="term-style">
+
+
<xsl:if test="parent::*[local-name() = 'term'] and not(preceding-sibling::*[local-name() = 'term'])">
</xsl:if>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'term']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'term']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'term']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<xsl:variable name="level">
<xsl:call-template name="getLevelTermName"/>
</xsl:variable>
<fo:inline role="H{$level}">
<xsl:apply-templates/>
- <!-- <xsl:if test="$namespace = 'gb' or $namespace = 'ogc'">
- <xsl:text>.</xsl:text>
- </xsl:if> -->
</fo:inline>
</xsl:if>
</xsl:template><xsl:template match="*[local-name() = 'figure']" name="figure">
<xsl:variable name="isAdded" select="@added"/>
<xsl:variable name="isDeleted" select="@deleted"/>
@@ -3703,28 +3757,30 @@
<xsl:call-template name="setTrackChangesStyles">
<xsl:with-param name="isAdded" select="$isAdded"/>
<xsl:with-param name="isDeleted" select="$isDeleted"/>
</xsl:call-template>
- <fo:block>
-
- <xsl:apply-templates/>
+
+
+ <fo:block xsl:use-attribute-sets="figure-style">
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
<xsl:call-template name="fn_display_figure"/>
<xsl:for-each select="*[local-name() = 'note']">
<xsl:call-template name="note"/>
</xsl:for-each>
- <xsl:apply-templates select="*[local-name() = 'name']" mode="presentation"/>
+ <xsl:apply-templates select="*[local-name() = 'name']"/> <!-- show figure's name AFTER image -->
+
</fo:block-container>
</xsl:template><xsl:template match="*[local-name() = 'figure'][@class = 'pseudocode']">
<fo:block id="{@id}">
- <xsl:apply-templates/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- <xsl:apply-templates select="*[local-name() = 'name']" mode="presentation"/>
+ <xsl:apply-templates select="*[local-name() = 'name']"/>
</xsl:template><xsl:template match="*[local-name() = 'figure'][@class = 'pseudocode']//*[local-name() = 'p']">
<fo:block xsl:use-attribute-sets="figure-pseudocode-p-style">
<xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'image']">
@@ -3827,13 +3883,11 @@
<xsl:variable name="decoder" select="java:java.util.Base64.getDecoder()"/>
<xsl:variable name="fileContent" select="java:decode($decoder, $base64String)"/>
<xsl:variable name="bis" select="java:java.io.ByteArrayInputStream.new($fileContent)"/>
<xsl:variable name="bufferedImage" select="java:javax.imageio.ImageIO.read($bis)"/>
<xsl:variable name="width" select="java:getWidth($bufferedImage)"/>
- <!-- width=<xsl:value-of select="$width"/> -->
<xsl:variable name="height" select="java:getHeight($bufferedImage)"/>
- <!-- height=<xsl:value-of select="$height"/> -->
<svg xmlns="http://www.w3.org/2000/svg" xml:space="preserve" style="enable-background:new 0 0 595.28 841.89;" height="{$height}" width="{$width}" viewBox="0 0 {$width} {$height}" y="0px" x="0px" id="Layer_1" version="1.1">
<image xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="{@src}" height="{$height}" width="{$width}" style="overflow:visible;"/>
<xsl:call-template name="svg_cross">
<xsl:with-param name="width" select="$width"/>
<xsl:with-param name="height" select="$height"/>
@@ -4099,11 +4153,11 @@
<fo:block> </fo:block></fo:block-container>
</fo:inline-container>
</fo:basic-link>
</fo:block>
</fo:block-container>
- </xsl:template><xsl:template match="*[local-name() = 'emf']"/><xsl:template match="*[local-name() = 'figure']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'figure']/*[local-name() = 'name'] | *[local-name() = 'table']/*[local-name() = 'name'] | *[local-name() = 'permission']/*[local-name() = 'name'] | *[local-name() = 'recommendation']/*[local-name() = 'name'] | *[local-name() = 'requirement']/*[local-name() = 'name']" mode="contents">
+ </xsl:template><xsl:template match="*[local-name() = 'emf']"/><xsl:template match="*[local-name() = 'figure']/*[local-name() = 'name'] | *[local-name() = 'table']/*[local-name() = 'name'] | *[local-name() = 'permission']/*[local-name() = 'name'] | *[local-name() = 'recommendation']/*[local-name() = 'name'] | *[local-name() = 'requirement']/*[local-name() = 'name']" mode="contents">
<xsl:apply-templates mode="contents"/>
<xsl:text> </xsl:text>
</xsl:template><xsl:template match="*[local-name() = 'figure']/*[local-name() = 'name'] | *[local-name() = 'table']/*[local-name() = 'name'] | *[local-name() = 'permission']/*[local-name() = 'name'] | *[local-name() = 'recommendation']/*[local-name() = 'name'] | *[local-name() = 'requirement']/*[local-name() = 'name'] | *[local-name() = 'sourcecode']/*[local-name() = 'name']" mode="bookmarks">
<xsl:apply-templates mode="bookmarks"/>
<xsl:text> </xsl:text>
@@ -4252,12 +4306,10 @@
-
-
</fo:bookmark-tree>
</xsl:if>
</xsl:template><xsl:template name="insertFigureBookmarks">
<xsl:param name="contents"/>
<xsl:if test="xalan:nodeset($contents)/figure">
@@ -4324,11 +4376,11 @@
</xsl:when>
<xsl:otherwise>
<xsl:apply-templates mode="bookmark"/>
</xsl:otherwise>
</xsl:choose>
- </xsl:template><xsl:template match="title" mode="bookmark"/><xsl:template match="text()" mode="bookmark"/><xsl:template match="*[local-name() = 'figure']/*[local-name() = 'name'] | *[local-name() = 'image']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="title" mode="bookmark"/><xsl:template match="text()" mode="bookmark"/><xsl:template match="*[local-name() = 'figure']/*[local-name() = 'name'] | *[local-name() = 'image']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<fo:block xsl:use-attribute-sets="figure-name-style">
<xsl:apply-templates/>
@@ -4340,16 +4392,10 @@
<xsl:with-param name="mode" select="$mode"/>
</xsl:apply-templates>
<!-- <xsl:text> </xsl:text> -->
</xsl:template><xsl:template name="getSection">
<xsl:value-of select="*[local-name() = 'title']/*[local-name() = 'tab'][1]/preceding-sibling::node()"/>
- <!--
- <xsl:for-each select="*[local-name() = 'title']/*[local-name() = 'tab'][1]/preceding-sibling::node()">
- <xsl:value-of select="."/>
- </xsl:for-each>
- -->
-
</xsl:template><xsl:template name="getName">
<xsl:choose>
<xsl:when test="*[local-name() = 'title']/*[local-name() = 'tab']">
<xsl:copy-of select="*[local-name() = 'title']/*[local-name() = 'tab'][1]/following-sibling::node()"/>
</xsl:when>
@@ -4414,20 +4460,25 @@
</xsl:template><xsl:template match="*[local-name() = 'name']" mode="contents_item">
<xsl:param name="mode">bookmarks</xsl:param>
<xsl:apply-templates mode="contents_item">
<xsl:with-param name="mode" select="$mode"/>
</xsl:apply-templates>
- </xsl:template><xsl:template match="*[local-name() = 'add'][starts-with(text(), $ace_tag)]" mode="contents_item">
+ </xsl:template><xsl:template match="*[local-name() = 'add']" mode="contents_item">
<xsl:param name="mode">bookmarks</xsl:param>
- <xsl:if test="$mode = 'contents'">
- <xsl:copy>
- <xsl:apply-templates mode="contents_item"/>
- </xsl:copy>
- </xsl:if>
+ <xsl:choose>
+ <xsl:when test="starts-with(text(), $ace_tag)">
+ <xsl:if test="$mode = 'contents'">
+ <xsl:copy>
+ <xsl:apply-templates mode="contents_item"/>
+ </xsl:copy>
+ </xsl:if>
+ </xsl:when>
+ <xsl:otherwise><xsl:apply-templates mode="contents_item"/></xsl:otherwise>
+ </xsl:choose>
</xsl:template><xsl:template match="*[local-name()='sourcecode']" name="sourcecode">
- <fo:block-container margin-left="0mm">
+ <fo:block-container xsl:use-attribute-sets="sourcecode-container-style">
<xsl:copy-of select="@id"/>
<xsl:if test="parent::*[local-name() = 'note']">
<xsl:attribute name="margin-left">
<xsl:choose>
@@ -4460,10 +4511,11 @@
</xsl:variable>
+
<xsl:variable name="font-size" select="normalize-space($_font-size)"/>
<xsl:if test="$font-size != ''">
<xsl:attribute name="font-size">
<xsl:choose>
<xsl:when test="$font-size = 'inherit'"><xsl:value-of select="$font-size"/></xsl:when>
@@ -4476,15 +4528,15 @@
- <xsl:apply-templates/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- <xsl:apply-templates select="*[local-name()='name']" mode="presentation"/>
+ <xsl:apply-templates select="*[local-name()='name']"/> <!-- show sourcecode's name AFTER content -->
</fo:block-container>
@@ -4494,22 +4546,22 @@
<xsl:call-template name="add-zero-spaces-equal"/>
</xsl:variable>
<xsl:call-template name="add-zero-spaces-java">
<xsl:with-param name="text" select="$text"/>
</xsl:call-template>
- </xsl:template><xsl:template match="*[local-name() = 'sourcecode']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'sourcecode']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'sourcecode']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<fo:block xsl:use-attribute-sets="sourcecode-name-style">
<xsl:apply-templates/>
</fo:block>
</xsl:if>
</xsl:template><xsl:template match="*[local-name() = 'permission']">
<fo:block id="{@id}" xsl:use-attribute-sets="permission-style">
- <xsl:apply-templates select="*[local-name()='name']" mode="presentation"/>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="*[local-name()='name']"/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'permission']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'permission']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'permission']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<fo:block xsl:use-attribute-sets="permission-name-style">
<xsl:apply-templates/>
</fo:block>
@@ -4518,52 +4570,52 @@
<fo:block xsl:use-attribute-sets="permission-label-style">
<xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'requirement']">
<fo:block id="{@id}" xsl:use-attribute-sets="requirement-style">
- <xsl:apply-templates select="*[local-name()='name']" mode="presentation"/>
- <xsl:apply-templates select="*[local-name()='label']" mode="presentation"/>
- <xsl:apply-templates select="@obligation" mode="presentation"/>
- <xsl:apply-templates select="*[local-name()='subject']" mode="presentation"/>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="*[local-name()='name']"/>
+ <xsl:apply-templates select="*[local-name()='label']"/>
+ <xsl:apply-templates select="@obligation"/>
+ <xsl:apply-templates select="*[local-name()='subject']"/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name') and not(local-name() = 'label') and not(local-name() = 'subject')]"/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<fo:block xsl:use-attribute-sets="requirement-name-style">
<xsl:apply-templates/>
</fo:block>
</xsl:if>
- </xsl:template><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'label']"/><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'label']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'label']">
<fo:block xsl:use-attribute-sets="requirement-label-style">
<xsl:apply-templates/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'requirement']/@obligation" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'requirement']/@obligation">
<fo:block>
<fo:inline padding-right="3mm">Obligation</fo:inline><xsl:value-of select="."/>
</fo:block>
+ </xsl:template><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'subject']" priority="2">
+ <fo:block xsl:use-attribute-sets="subject-style">
+ <xsl:text>Target Type </xsl:text><xsl:apply-templates/>
+ </fo:block>
</xsl:template><xsl:template match="*[local-name() = 'recommendation']">
<fo:block id="{@id}" xsl:use-attribute-sets="recommendation-style">
- <xsl:apply-templates select="*[local-name()='name']" mode="presentation"/>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="*[local-name()='name']"/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'recommendation']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'recommendation']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'recommendation']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<fo:block xsl:use-attribute-sets="recommendation-name-style">
<xsl:apply-templates/>
</fo:block>
</xsl:if>
</xsl:template><xsl:template match="*[local-name() = 'recommendation']/*[local-name() = 'label']">
<fo:block xsl:use-attribute-sets="recommendation-label-style">
<xsl:apply-templates/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'subject']" priority="2"/><xsl:template match="*[local-name() = 'requirement']/*[local-name() = 'subject']" mode="presentation">
- <fo:block xsl:use-attribute-sets="subject-style">
- <xsl:text>Target Type </xsl:text><xsl:apply-templates/>
- </fo:block>
</xsl:template><xsl:template match="*[local-name() = 'subject']">
<fo:block xsl:use-attribute-sets="subject-style">
<xsl:text>Target Type </xsl:text><xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'inherit'] | *[local-name() = 'component'][@class = 'inherit']">
@@ -4603,22 +4655,20 @@
<xsl:variable name="simple-table">
<xsl:call-template name="getSimpleTable"/>
</xsl:variable>
<xsl:variable name="cols-count" select="count(xalan:nodeset($simple-table)//tr[1]/td)"/>
<xsl:if test="$cols-count = 2 and not(ancestor::*[local-name()='table'])">
- <!-- <fo:table-column column-width="35mm"/>
- <fo:table-column column-width="115mm"/> -->
<fo:table-column column-width="30%"/>
<fo:table-column column-width="70%"/>
</xsl:if>
<xsl:apply-templates mode="requirement"/>
</fo:table>
<!-- fn processing -->
<xsl:if test=".//*[local-name() = 'fn']">
<xsl:for-each select="*[local-name() = 'tbody']">
<fo:block font-size="90%" border-bottom="1pt solid black">
- <xsl:call-template name="fn_display"/>
+ <xsl:call-template name="table_fn_display"/>
</fo:block>
</xsl:for-each>
</xsl:if>
</fo:block-container>
</fo:block-container>
@@ -4631,11 +4681,10 @@
<xsl:apply-templates mode="requirement"/>
</fo:table-body>
</xsl:template><xsl:template match="*[local-name()='tr']" mode="requirement">
<fo:table-row height="7mm" border-bottom="0.5pt solid grey">
<xsl:if test="parent::*[local-name()='thead']"> <!-- and not(ancestor::*[local-name() = 'table'][@class = 'recommendation' or @class='requirement' or @class='permission']) -->
- <!-- <xsl:attribute name="border">1pt solid black</xsl:attribute> -->
<xsl:attribute name="background-color">rgb(33, 55, 92)</xsl:attribute>
</xsl:if>
<xsl:if test="starts-with(*[local-name()='td'][1], 'Requirement ')">
<xsl:attribute name="background-color">rgb(252, 246, 222)</xsl:attribute>
</xsl:if>
@@ -4644,38 +4693,15 @@
</xsl:if>
<xsl:apply-templates mode="requirement"/>
</fo:table-row>
</xsl:template><xsl:template match="*[local-name()='th']" mode="requirement">
<fo:table-cell text-align="{@align}" display-align="center" padding="1mm" padding-left="2mm"> <!-- border="0.5pt solid black" -->
- <xsl:attribute name="text-align">
- <xsl:choose>
- <xsl:when test="@align">
- <xsl:value-of select="@align"/>
- </xsl:when>
- <xsl:otherwise>left</xsl:otherwise>
- </xsl:choose>
- </xsl:attribute>
- <xsl:if test="@colspan">
- <xsl:attribute name="number-columns-spanned">
- <xsl:value-of select="@colspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:if test="@rowspan">
- <xsl:attribute name="number-rows-spanned">
- <xsl:value-of select="@rowspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:call-template name="display-align"/>
+ <xsl:call-template name="setTextAlignment">
+ <xsl:with-param name="default">left</xsl:with-param>
+ </xsl:call-template>
- <!-- <xsl:if test="ancestor::*[local-name()='table']/@type = 'recommend'">
- <xsl:attribute name="padding-top">0.5mm</xsl:attribute>
- <xsl:attribute name="background-color">rgb(165, 165, 165)</xsl:attribute>
- </xsl:if>
- <xsl:if test="ancestor::*[local-name()='table']/@type = 'recommendtest'">
- <xsl:attribute name="padding-top">0.5mm</xsl:attribute>
- <xsl:attribute name="background-color">rgb(201, 201, 201)</xsl:attribute>
- </xsl:if> -->
+ <xsl:call-template name="setTableCellAttributes"/>
<fo:block>
<xsl:apply-templates/>
</fo:block>
</fo:table-cell>
@@ -4683,41 +4709,19 @@
<fo:table-cell text-align="{@align}" display-align="center" padding="1mm" padding-left="2mm"> <!-- border="0.5pt solid black" -->
<xsl:if test="*[local-name() = 'table'][@class = 'recommendation' or @class='requirement' or @class='permission']">
<xsl:attribute name="padding">0mm</xsl:attribute>
<xsl:attribute name="padding-left">0mm</xsl:attribute>
</xsl:if>
- <xsl:attribute name="text-align">
- <xsl:choose>
- <xsl:when test="@align">
- <xsl:value-of select="@align"/>
- </xsl:when>
- <xsl:otherwise>left</xsl:otherwise>
- </xsl:choose>
- </xsl:attribute>
+ <xsl:call-template name="setTextAlignment">
+ <xsl:with-param name="default">left</xsl:with-param>
+ </xsl:call-template>
+
<xsl:if test="following-sibling::*[local-name()='td'] and not(preceding-sibling::*[local-name()='td'])">
<xsl:attribute name="font-weight">bold</xsl:attribute>
</xsl:if>
- <xsl:if test="@colspan">
- <xsl:attribute name="number-columns-spanned">
- <xsl:value-of select="@colspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:if test="@rowspan">
- <xsl:attribute name="number-rows-spanned">
- <xsl:value-of select="@rowspan"/>
- </xsl:attribute>
- </xsl:if>
- <xsl:call-template name="display-align"/>
- <!-- <xsl:if test="ancestor::*[local-name()='table']/@type = 'recommend'">
- <xsl:attribute name="padding-left">0.5mm</xsl:attribute>
- <xsl:attribute name="padding-top">0.5mm</xsl:attribute>
- <xsl:if test="parent::*[local-name()='tr']/preceding-sibling::*[local-name()='tr'] and not(*[local-name()='table'])">
- <xsl:attribute name="background-color">rgb(201, 201, 201)</xsl:attribute>
- </xsl:if>
- </xsl:if> -->
- <!-- 2nd line and below -->
+ <xsl:call-template name="setTableCellAttributes"/>
<fo:block>
<xsl:apply-templates/>
</fo:block>
</fo:table-cell>
@@ -4725,19 +4729,19 @@
<fo:block font-size="11pt">
<xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'p2'][ancestor::*[local-name() = 'table'][@class = 'recommendation' or @class='requirement' or @class='permission']]">
- <fo:block> <!-- margin-bottom="10pt" -->
+ <fo:block>
<xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'termexample']">
<fo:block id="{@id}" xsl:use-attribute-sets="termexample-style">
- <xsl:apply-templates select="*[local-name()='name']" mode="presentation"/>
- <xsl:apply-templates/>
+ <xsl:apply-templates select="*[local-name()='name']"/>
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'termexample']/*[local-name() = 'name']"/><xsl:template match="*[local-name() = 'termexample']/*[local-name() = 'name']" mode="presentation">
+ </xsl:template><xsl:template match="*[local-name() = 'termexample']/*[local-name() = 'name']">
<xsl:if test="normalize-space() != ''">
<fo:inline xsl:use-attribute-sets="termexample-name-style">
<xsl:apply-templates/>
</fo:inline>
</xsl:if>
@@ -4759,13 +4763,11 @@
<fo:block id="{@id}" xsl:use-attribute-sets="example-style">
<xsl:variable name="fo_element">
<xsl:if test=".//*[local-name() = 'table'] or .//*[local-name() = 'dl']">block</xsl:if>
- block
-
-
+ block
</xsl:variable>
<!-- display 'EXAMPLE' -->
<xsl:apply-templates select="*[local-name()='name']">
<xsl:with-param name="fo_element" select="$fo_element"/>
@@ -4834,10 +4836,12 @@
</xsl:otherwise>
</xsl:choose>
</xsl:template><xsl:template match="*[local-name() = 'termsource']" name="termsource">
<fo:block xsl:use-attribute-sets="termsource-style">
+
+
<!-- Example: [SOURCE: ISO 5127:2017, 3.1.6.02] -->
<xsl:variable name="termsource_text">
<xsl:apply-templates/>
</xsl:variable>
<xsl:copy-of select="$termsource_text"/>
@@ -4871,13 +4875,11 @@
</xsl:template><xsl:template match="*[local-name() = 'termsource']/text()">
<xsl:if test="normalize-space() != ''">
<xsl:value-of select="."/>
</xsl:if>
</xsl:template><xsl:template match="*[local-name() = 'termsource']/*[local-name() = 'strong'][1][following-sibling::*[1][local-name() = 'origin']]/text()">
- <fo:inline>
-
-
+ <fo:inline xsl:use-attribute-sets="termsource-text-style">
<xsl:value-of select="."/>
</fo:inline>
</xsl:template><xsl:template match="*[local-name() = 'origin']">
<fo:basic-link internal-destination="{@bibitemid}" fox:alt-text="{@citeas}">
<xsl:if test="normalize-space(@citeas) = ''">
@@ -4916,11 +4918,10 @@
<fo:block-container margin-left="0mm">
<fo:block xsl:use-attribute-sets="quote-style">
- <!-- <xsl:apply-templates select=".//*[local-name() = 'p']"/> -->
<xsl:apply-templates select="./node()[not(local-name() = 'author') and not(local-name() = 'source')]"/> <!-- process all nested nodes, except author and source -->
</fo:block>
<xsl:if test="*[local-name() = 'author'] or *[local-name() = 'source']">
<fo:block xsl:use-attribute-sets="quote-source-style">
@@ -4959,20 +4960,18 @@
<xsl:otherwise><xsl:value-of select="@bibitemid"/></xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:choose>
- <xsl:when test="normalize-space($bibitemid) != ''">
+ <xsl:when test="normalize-space($bibitemid) != ''"> <!-- if in the bibliography there is the item with @bibitemid (and not hidden), then create link -->
<fo:inline xsl:use-attribute-sets="eref-style">
<xsl:if test="@type = 'footnote'">
+ <xsl:attribute name="keep-together.within-line">always</xsl:attribute>
+ <xsl:attribute name="keep-with-previous.within-line">always</xsl:attribute>
+ <xsl:attribute name="vertical-align">super</xsl:attribute>
+ <xsl:attribute name="font-size">80%</xsl:attribute>
- <xsl:attribute name="keep-together.within-line">always</xsl:attribute>
- <xsl:attribute name="font-size">80%</xsl:attribute>
- <xsl:attribute name="keep-with-previous.within-line">always</xsl:attribute>
- <xsl:attribute name="vertical-align">super</xsl:attribute>
-
-
</xsl:if>
<xsl:variable name="citeas" select="java:replaceAll(java:java.lang.String.new(@citeas),'^\[?(.+?)\]?$','$1')"/> <!-- remove leading and trailing brackets -->
<xsl:variable name="text" select="normalize-space()"/>
@@ -4987,11 +4986,10 @@
<xsl:attribute name="color">blue</xsl:attribute>
<xsl:attribute name="text-decoration">underline</xsl:attribute>
-
</xsl:if>
<xsl:apply-templates/>
@@ -5046,12 +5044,10 @@
<xsl:value-of select="normalize-space($padding)"/>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
- <!-- <xsl:variable name="language" select="//*[local-name()='bibdata']//*[local-name()='language']"/> -->
-
<xsl:choose>
<xsl:when test="$lang = 'zh'">
<fo:inline><xsl:value-of select="$tab_zh"/></fo:inline>
</xsl:when>
<xsl:when test="../../@inline-header = 'true'">
@@ -5103,11 +5099,10 @@
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'definition'][preceding-sibling::*[local-name() = 'domain']]">
<xsl:apply-templates/>
</xsl:template><xsl:template match="*[local-name() = 'definition'][preceding-sibling::*[local-name() = 'domain']]/*[local-name() = 'p'][1]">
<fo:inline> <xsl:apply-templates/></fo:inline>
- <!-- <fo:block> </fo:block> -->
<fo:block/>
</xsl:template><xsl:template match="/*/*[local-name() = 'sections']/*" priority="2">
<fo:block>
<xsl:call-template name="setId"/>
@@ -5147,15 +5142,10 @@
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'definitions']">
<fo:block id="{@id}">
<xsl:apply-templates/>
</fo:block>
- </xsl:template><xsl:template match="*[local-name() = 'references'][@hidden='true']" priority="3"/><xsl:template match="*[local-name() = 'bibitem'][@hidden='true']" priority="3"/><xsl:template match="/*/*[local-name() = 'bibliography']/*[local-name() = 'references'][@normative='true']">
-
- <fo:block id="{@id}">
- <xsl:apply-templates/>
- </fo:block>
</xsl:template><xsl:template match="*[local-name() = 'annex']">
<fo:block break-after="page"/>
<fo:block id="{@id}">
</fo:block>
@@ -5416,60 +5406,104 @@
</fo:table-row>
</xsl:template><xsl:template match="*[local-name() = 'errata']/*[local-name() = 'row']/*">
<fo:table-cell border="1pt solid black" padding-left="1mm" padding-top="0.5mm">
<fo:block><xsl:apply-templates/></fo:block>
</fo:table-cell>
- </xsl:template><xsl:template name="processBibitem">
+ </xsl:template><xsl:template match="*[local-name() = 'references'][@hidden='true']" priority="3"/><xsl:template match="*[local-name() = 'bibitem'][@hidden='true']" priority="3"/><xsl:template match="*[local-name() = 'bibitem'][starts-with(@id, 'hidden_bibitem_')]" priority="3"/><xsl:template match="*[local-name() = 'references'][@normative='true']" priority="2">
+ <fo:block id="{@id}">
+ <xsl:apply-templates/>
+ </fo:block>
+ </xsl:template><xsl:template match="*[local-name() = 'references']">
+ <xsl:if test="not(ancestor::*[local-name() = 'annex'])">
+
+ <fo:block break-after="page"/>
+
+ </xsl:if>
-
-
-
-
- <!-- start CSD bibtem processing -->
- <xsl:if test=".//csd:fn">
- <xsl:attribute name="line-height-shift-adjustment">disregard-shifts</xsl:attribute>
+ <!-- <xsl:if test="ancestor::*[local-name() = 'annex']">
+ <xsl:if test="$namespace = 'csa' or $namespace = 'csd' or $namespace = 'gb' or $namespace = 'iec' or $namespace = 'iso' or $namespace = 'itu'">
+ <fo:block break-after="page"/>
</xsl:if>
- <xsl:variable name="docidentifier">
- <xsl:choose>
- <xsl:when test="*[local-name() = 'docidentifier']/@type = 'metanorma'"/>
- <xsl:otherwise><xsl:value-of select="*[local-name() = 'docidentifier'][not(@type = 'metanorma-ordinal')]"/></xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
- <xsl:value-of select="$docidentifier"/>
- <xsl:apply-templates select="csd:note"/>
- <xsl:if test="normalize-space($docidentifier) != ''">, </xsl:if>
- <xsl:choose>
- <xsl:when test="csd:title[@type = 'main' and @language = 'en']">
- <xsl:apply-templates select="csd:title[@type = 'main' and @language = 'en']"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:apply-templates select="csd:title"/>
- </xsl:otherwise>
- </xsl:choose>
- <xsl:apply-templates select="csd:formattedref"/>
- <!-- end CSD bibtem processing -->
+ </xsl:if> -->
+ <fo:block id="{@id}" xsl:use-attribute-sets="references-non-normative-style">
+ <xsl:apply-templates/>
+ </fo:block>
-
+ </xsl:template><xsl:template match="*[local-name() = 'bibitem']">
+ <xsl:call-template name="bibitem"/>
+ </xsl:template><xsl:template match="*[local-name() = 'references'][@normative='true']/*[local-name() = 'bibitem']" name="bibitem" priority="2">
+ <fo:block id="{@id}" xsl:use-attribute-sets="bibitem-normative-style">
+ <xsl:call-template name="processBibitem"/>
+ </fo:block>
+
+ </xsl:template><xsl:template match="*[local-name() = 'references'][not(@normative='true')]/*[local-name() = 'bibitem']" priority="2">
-
+ <!-- $namespace = 'csd' or $namespace = 'gb' or $namespace = 'iec' or $namespace = 'iso' or $namespace = 'jcgm' or $namespace = 'm3d' or
+ $namespace = 'mpfd' or $namespace = 'ogc' or $namespace = 'ogc-white-paper' -->
+ <!-- Example: [1] ISO 9:1995, Information and documentation – Transliteration of Cyrillic characters into Latin characters – Slavic and non-Slavic languages -->
+ <fo:list-block id="{@id}" xsl:use-attribute-sets="bibitem-non-normative-list-style">
+ <fo:list-item>
+ <fo:list-item-label end-indent="label-end()">
+ <fo:block>
+ <fo:inline>
+
+ <xsl:value-of select="*[local-name()='docidentifier'][@type = 'metanorma-ordinal']"/>
+ <xsl:if test="not(*[local-name()='docidentifier'][@type = 'metanorma-ordinal'])">
+ <xsl:number format="[1]"/>
+ </xsl:if>
+
+ </fo:inline>
+ </fo:block>
+ </fo:list-item-label>
+ <fo:list-item-body start-indent="body-start()">
+ <fo:block xsl:use-attribute-sets="bibitem-non-normative-list-body-style">
+ <xsl:call-template name="processBibitem"/>
+ </fo:block>
+ </fo:list-item-body>
+ </fo:list-item>
+ </fo:list-block>
+
- <!-- end MPFD bibitem processing -->
+ </xsl:template><xsl:template name="processBibitem">
- <!-- start M3D bibitem processing -->
-
-
-
+ <!-- start bibitem processing -->
+ <xsl:if test=".//*[local-name() = 'fn']">
+ <xsl:attribute name="line-height-shift-adjustment">disregard-shifts</xsl:attribute>
+ </xsl:if>
+ <xsl:variable name="docidentifier">
+ <xsl:choose>
+ <xsl:when test="*[local-name() = 'docidentifier']/@type = 'metanorma'"/>
+ <xsl:otherwise><xsl:value-of select="*[local-name() = 'docidentifier'][not(@type = 'metanorma-ordinal')]"/></xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
+ <fo:inline><xsl:value-of select="$docidentifier"/></fo:inline>
+ <xsl:apply-templates select="*[local-name() = 'note']"/>
+ <xsl:if test="normalize-space($docidentifier) != ''">, </xsl:if>
+ <xsl:choose>
+ <xsl:when test="*[local-name() = 'title'][@type = 'main' and @language = $lang]">
+ <xsl:apply-templates select="*[local-name() = 'title'][@type = 'main' and @language = $lang]"/>
+ </xsl:when>
+ <xsl:when test="*[local-name() = 'title'][@type = 'main' and @language = 'en']">
+ <xsl:apply-templates select="*[local-name() = 'title'][@type = 'main' and @language = 'en']"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:apply-templates select="*[local-name() = 'title']"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ <xsl:apply-templates select="*[local-name() = 'formattedref']"/>
+ <!-- end bibitem processing -->
+
</xsl:template><xsl:template name="processBibitemDocId">
<xsl:variable name="_doc_ident" select="*[local-name() = 'docidentifier'][not(@type = 'DOI' or @type = 'metanorma' or @type = 'metanorma-ordinal' or @type = 'ISSN' or @type = 'ISBN' or @type = 'rfc-anchor')]"/>
<xsl:choose>
<xsl:when test="normalize-space($_doc_ident) != ''">
<!-- <xsl:variable name="type" select="*[local-name() = 'docidentifier'][not(@type = 'DOI' or @type = 'metanorma' or @type = 'ISSN' or @type = 'ISBN' or @type = 'rfc-anchor')]/@type"/>
@@ -5522,10 +5556,59 @@
<xsl:value-of select="translate(.,'. ','')"/>
</xsl:template><xsl:template match="*[local-name() = 'name']/*[local-name() = 'forename']/text()" mode="strip">
<xsl:value-of select="substring(.,1,1)"/>
</xsl:template><xsl:template match="*[local-name() = 'title']" mode="title">
<fo:inline><xsl:apply-templates/></fo:inline>
+ </xsl:template><xsl:template match="*[local-name() = 'bibitem']/*[local-name() = 'title']" priority="2">
+ <!-- <fo:inline><xsl:apply-templates /></fo:inline> -->
+ <fo:inline font-style="italic"> <!-- BIPM BSI CSD CSA GB IEC IHO ISO ITU JCGM -->
+ <xsl:apply-templates/>
+ </fo:inline>
+ </xsl:template><xsl:template match="*[local-name() = 'bibitem']/*[local-name() = 'note']" priority="2">
+ <fo:footnote>
+ <xsl:variable name="number">
+
+ <xsl:choose>
+ <xsl:when test="ancestor::*[local-name() = 'references'][preceding-sibling::*[local-name() = 'references']]">
+ <xsl:number level="any" count="*[local-name() = 'references'][preceding-sibling::*[local-name() = 'references']]//*[local-name() = 'bibitem']/*[local-name() = 'note']"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:number level="any" count="*[local-name() = 'bibitem']/*[local-name() = 'note']"/>
+ </xsl:otherwise>
+ </xsl:choose>
+
+ </xsl:variable>
+ <fo:inline xsl:use-attribute-sets="bibitem-note-fn-style">
+ <fo:basic-link internal-destination="{generate-id()}" fox:alt-text="footnote {$number}">
+ <xsl:value-of select="$number"/>
+
+ </fo:basic-link>
+ </fo:inline>
+ <fo:footnote-body>
+ <fo:block xsl:use-attribute-sets="bibitem-note-fn-body-style">
+ <fo:inline id="{generate-id()}" xsl:use-attribute-sets="bibitem-note-fn-number-style">
+ <xsl:value-of select="$number"/>
+
+ </fo:inline>
+ <xsl:apply-templates/>
+ </fo:block>
+ </fo:footnote-body>
+ </fo:footnote>
+ </xsl:template><xsl:template match="*[local-name() = 'bibitem']/*[local-name() = 'edition']"> <!-- for iho -->
+ <xsl:text> edition </xsl:text>
+ <xsl:value-of select="."/>
+ </xsl:template><xsl:template match="*[local-name() = 'bibitem']/*[local-name() = 'uri']"> <!-- for iho -->
+ <xsl:text> (</xsl:text>
+ <fo:inline xsl:use-attribute-sets="link-style">
+ <fo:basic-link external-destination="." fox:alt-text=".">
+ <xsl:value-of select="."/>
+ </fo:basic-link>
+ </fo:inline>
+ <xsl:text>)</xsl:text>
+ </xsl:template><xsl:template match="*[local-name() = 'bibitem']/*[local-name() = 'docidentifier']"/><xsl:template match="*[local-name() = 'formattedref']">
+
+ <xsl:apply-templates/>
</xsl:template><xsl:template match="*[local-name() = 'form']">
<fo:block>
<xsl:apply-templates/>
</fo:block>
</xsl:template><xsl:template match="*[local-name() = 'form']//*[local-name() = 'label']">
@@ -5594,28 +5677,11 @@
<xsl:variable name="toclevels" select="normalize-space(//*[local-name() = 'misc-container']/*[local-name() = 'presentation-metadata'][*[local-name() = 'name']/text() = 'TOC Heading Levels']/*[local-name() = 'value'])"/> <!-- Number of table of contents levels to render -->
<xsl:choose>
<xsl:when test="$htmltoclevels != ''"><xsl:value-of select="number($htmltoclevels)"/></xsl:when> <!-- if there is value in xml -->
<xsl:when test="$toclevels != ''"><xsl:value-of select="number($toclevels)"/></xsl:when> <!-- if there is value in xml -->
<xsl:otherwise><!-- default value -->
-
-
-
2
-
-
-
-
-
-
-
-
-
-
-
-
-
-
</xsl:otherwise>
</xsl:choose>
</xsl:variable><xsl:template match="*[local-name() = 'toc']">
<xsl:param name="colwidths"/>
<xsl:variable name="colwidths_">
@@ -5709,90 +5775,101 @@
</fo:inline>
</xsl:template><xsl:template match="@language">
<xsl:copy-of select="."/>
</xsl:template><xsl:template match="*[local-name() = 'p'][@type = 'floating-title']" priority="4">
<xsl:call-template name="title"/>
+ </xsl:template><xsl:template match="*[local-name() = 'admonition']">
+
+
+
+
+
+
+ <fo:block xsl:use-attribute-sets="admonition-style">
+
+
+
+
+
+
+ <xsl:call-template name="displayAdmonitionName"/>
+ <xsl:text> — </xsl:text>
+
+
+ <xsl:apply-templates select="node()[not(local-name() = 'name')]"/>
+ </fo:block>
+
+ </xsl:template><xsl:template name="displayAdmonitionName">
+
+ <xsl:apply-templates select="*[local-name() = 'name']"/>
+ <xsl:if test="not(*[local-name() = 'name'])">
+ <xsl:apply-templates select="@type"/>
+ </xsl:if>
+
+ </xsl:template><xsl:template match="*[local-name() = 'admonition']/*[local-name() = 'name']">
+ <xsl:apply-templates/>
+ </xsl:template><xsl:template match="*[local-name() = 'admonition']/@type">
+ <xsl:variable name="admonition_type_">
+ <xsl:call-template name="getLocalizedString">
+ <xsl:with-param name="key">admonition.<xsl:value-of select="."/></xsl:with-param>
+ </xsl:call-template>
+ </xsl:variable>
+ <xsl:variable name="admonition_type" select="normalize-space(java:toUpperCase(java:java.lang.String.new($admonition_type_)))"/>
+ <xsl:value-of select="$admonition_type"/>
+ <xsl:if test="$admonition_type = ''">
+ <xsl:value-of select="java:toUpperCase(java:java.lang.String.new(.))"/>
+ </xsl:if>
+ </xsl:template><xsl:template match="*[local-name() = 'admonition']/*[local-name() = 'p']">
+
+ <fo:block xsl:use-attribute-sets="admonition-p-style">
+
+
+
+ <xsl:apply-templates/>
+ </fo:block>
+
</xsl:template><xsl:template name="convertDate">
<xsl:param name="date"/>
<xsl:param name="format" select="'short'"/>
<xsl:variable name="year" select="substring($date, 1, 4)"/>
<xsl:variable name="month" select="substring($date, 6, 2)"/>
<xsl:variable name="day" select="substring($date, 9, 2)"/>
<xsl:variable name="monthStr">
<xsl:choose>
- <xsl:when test="$month = '01'">January</xsl:when>
- <xsl:when test="$month = '02'">February</xsl:when>
- <xsl:when test="$month = '03'">March</xsl:when>
- <xsl:when test="$month = '04'">April</xsl:when>
- <xsl:when test="$month = '05'">May</xsl:when>
- <xsl:when test="$month = '06'">June</xsl:when>
- <xsl:when test="$month = '07'">July</xsl:when>
- <xsl:when test="$month = '08'">August</xsl:when>
- <xsl:when test="$month = '09'">September</xsl:when>
- <xsl:when test="$month = '10'">October</xsl:when>
- <xsl:when test="$month = '11'">November</xsl:when>
- <xsl:when test="$month = '12'">December</xsl:when>
+ <xsl:when test="$month = '01'">january</xsl:when>
+ <xsl:when test="$month = '02'">february</xsl:when>
+ <xsl:when test="$month = '03'">march</xsl:when>
+ <xsl:when test="$month = '04'">april</xsl:when>
+ <xsl:when test="$month = '05'">may</xsl:when>
+ <xsl:when test="$month = '06'">june</xsl:when>
+ <xsl:when test="$month = '07'">july</xsl:when>
+ <xsl:when test="$month = '08'">august</xsl:when>
+ <xsl:when test="$month = '09'">september</xsl:when>
+ <xsl:when test="$month = '10'">october</xsl:when>
+ <xsl:when test="$month = '11'">november</xsl:when>
+ <xsl:when test="$month = '12'">december</xsl:when>
</xsl:choose>
</xsl:variable>
- <xsl:variable name="result">
- <xsl:choose>
- <xsl:when test="$format = 'ddMMyyyy'">
- <xsl:if test="$day != ''"><xsl:value-of select="number($day)"/></xsl:if>
- <xsl:text> </xsl:text>
- <xsl:value-of select="normalize-space(concat($monthStr, ' ' , $year))"/>
- </xsl:when>
- <xsl:when test="$format = 'ddMM'">
- <xsl:if test="$day != ''"><xsl:value-of select="number($day)"/></xsl:if>
- <xsl:text> </xsl:text><xsl:value-of select="$monthStr"/>
- </xsl:when>
- <xsl:when test="$format = 'short' or $day = ''">
- <xsl:value-of select="normalize-space(concat($monthStr, ' ', $year))"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:value-of select="normalize-space(concat($monthStr, ' ', $day, ', ' , $year))"/>
- </xsl:otherwise>
- </xsl:choose>
+ <xsl:variable name="monthStr_localized">
+ <xsl:if test="normalize-space($monthStr) != ''"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_<xsl:value-of select="$monthStr"/></xsl:with-param></xsl:call-template></xsl:if>
</xsl:variable>
- <xsl:value-of select="$result"/>
- </xsl:template><xsl:template name="convertDateLocalized">
- <xsl:param name="date"/>
- <xsl:param name="format" select="'short'"/>
- <xsl:variable name="year" select="substring($date, 1, 4)"/>
- <xsl:variable name="month" select="substring($date, 6, 2)"/>
- <xsl:variable name="day" select="substring($date, 9, 2)"/>
- <xsl:variable name="monthStr">
- <xsl:choose>
- <xsl:when test="$month = '01'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_january</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '02'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_february</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '03'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_march</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '04'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_april</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '05'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_may</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '06'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_june</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '07'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_july</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '08'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_august</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '09'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_september</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '10'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_october</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '11'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_november</xsl:with-param></xsl:call-template></xsl:when>
- <xsl:when test="$month = '12'"><xsl:call-template name="getLocalizedString"><xsl:with-param name="key">month_december</xsl:with-param></xsl:call-template></xsl:when>
- </xsl:choose>
- </xsl:variable>
<xsl:variable name="result">
<xsl:choose>
<xsl:when test="$format = 'ddMMyyyy'">
<xsl:if test="$day != ''"><xsl:value-of select="number($day)"/></xsl:if>
<xsl:text> </xsl:text>
- <xsl:value-of select="normalize-space(concat($monthStr, ' ' , $year))"/>
+ <xsl:value-of select="normalize-space(concat($monthStr_localized, ' ' , $year))"/>
</xsl:when>
<xsl:when test="$format = 'ddMM'">
<xsl:if test="$day != ''"><xsl:value-of select="number($day)"/></xsl:if>
- <xsl:text> </xsl:text><xsl:value-of select="$monthStr"/>
+ <xsl:text> </xsl:text><xsl:value-of select="$monthStr_localized"/>
</xsl:when>
<xsl:when test="$format = 'short' or $day = ''">
- <xsl:value-of select="normalize-space(concat($monthStr, ' ', $year))"/>
+ <xsl:value-of select="normalize-space(concat($monthStr_localized, ' ', $year))"/>
</xsl:when>
<xsl:otherwise>
- <xsl:value-of select="normalize-space(concat($monthStr, ' ', $day, ', ' , $year))"/>
+ <xsl:value-of select="normalize-space(concat($monthStr_localized, ' ', $day, ', ' , $year))"/>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:value-of select="$result"/>
</xsl:template><xsl:template name="insertKeywords">
@@ -5840,18 +5917,13 @@
<rdf:Description xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:pdf="http://ns.adobe.com/pdf/1.3/" rdf:about="">
<!-- Dublin Core properties go here -->
<dc:title>
<xsl:variable name="title">
<xsl:for-each select="(//*[contains(local-name(), '-standard')])[1]/*[local-name() = 'bibdata']">
-
-
-
- <xsl:value-of select="*[local-name() = 'title'][@language = $lang]"/>
-
-
-
+ <xsl:value-of select="*[local-name() = 'title'][@language = $lang]"/>
+
</xsl:for-each>
</xsl:variable>
<xsl:choose>
<xsl:when test="normalize-space($title) != ''">
<xsl:value-of select="$title"/>
@@ -5862,25 +5934,22 @@
</xsl:choose>
</dc:title>
<dc:creator>
<xsl:for-each select="(//*[contains(local-name(), '-standard')])[1]/*[local-name() = 'bibdata']">
- <xsl:for-each select="*[local-name() = 'contributor'][*[local-name() = 'role']/@type='author']">
- <xsl:value-of select="*[local-name() = 'organization']/*[local-name() = 'name']"/>
- <xsl:if test="position() != last()">; </xsl:if>
- </xsl:for-each>
-
-
-
+ <xsl:for-each select="*[local-name() = 'contributor'][*[local-name() = 'role']/@type='author']">
+ <xsl:value-of select="*[local-name() = 'organization']/*[local-name() = 'name']"/>
+ <xsl:if test="position() != last()">; </xsl:if>
+ </xsl:for-each>
+
</xsl:for-each>
</dc:creator>
<dc:description>
<xsl:variable name="abstract">
- <xsl:copy-of select="//*[contains(local-name(), '-standard')]/*[local-name() = 'preface']/*[local-name() = 'abstract']//text()"/>
-
-
+ <xsl:copy-of select="//*[contains(local-name(), '-standard')]/*[local-name() = 'preface']/*[local-name() = 'abstract']//text()"/>
+
</xsl:variable>
<xsl:value-of select="normalize-space($abstract)"/>
</dc:description>
<pdf:Keywords>
<xsl:call-template name="insertKeywords"/>
@@ -5896,11 +5965,10 @@
<xsl:choose>
<xsl:when test="../@id">
<xsl:value-of select="../@id"/>
</xsl:when>
<xsl:otherwise>
- <!-- <xsl:value-of select="concat(local-name(..), '_', text())"/> -->
<xsl:value-of select="concat(generate-id(..), '_', text())"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template><xsl:template name="getLevel">
<xsl:param name="depth"/>
@@ -5922,13 +5990,10 @@
<xsl:value-of select="$level_total - 1"/>
</xsl:when>
<xsl:when test="ancestor::*[local-name() = 'preface']">
<xsl:value-of select="$level_total - 2"/>
</xsl:when>
- <!-- <xsl:when test="parent::*[local-name() = 'sections']">
- <xsl:value-of select="$level_total - 1"/>
- </xsl:when> -->
<xsl:when test="ancestor::*[local-name() = 'sections']">
<xsl:value-of select="$level_total - 1"/>
</xsl:when>
<xsl:when test="ancestor::*[local-name() = 'bibliography']">
<xsl:value-of select="$level_total - 1"/>
@@ -6114,11 +6179,10 @@
</xsl:call-template>
</xsl:variable>
<xsl:value-of select="$key_"/>
</xsl:otherwise>
</xsl:choose>
-
</xsl:template><xsl:template name="setTrackChangesStyles">
<xsl:param name="isAdded"/>
<xsl:param name="isDeleted"/>
<xsl:choose>
<xsl:when test="local-name() = 'math'">
@@ -6137,11 +6201,10 @@
<xsl:if test="$isDeleted = 'true'">
<xsl:attribute name="border"><xsl:value-of select="$border-block-deleted"/></xsl:attribute>
<xsl:if test="local-name() = 'table'">
<xsl:attribute name="background-color">rgb(255, 185, 185)</xsl:attribute>
</xsl:if>
- <!-- <xsl:attribute name="color"><xsl:value-of select="$color-deleted-text"/></xsl:attribute> -->
<xsl:attribute name="padding">2mm</xsl:attribute>
</xsl:if>
</xsl:otherwise>
</xsl:choose>
</xsl:template><xsl:variable name="LRM" select="''"/><xsl:variable name="RLM" select="''"/><xsl:template name="setWritingMode">
@@ -6157,18 +6220,21 @@
<xsl:value-of select="$align"/>
</xsl:when>
</xsl:choose>
</xsl:template><xsl:template name="setTextAlignment">
<xsl:param name="default">left</xsl:param>
+ <xsl:variable name="align" select="normalize-space(@align)"/>
<xsl:attribute name="text-align">
<xsl:choose>
- <xsl:when test="@align and not(@align = 'indent')"><xsl:value-of select="@align"/></xsl:when>
+ <xsl:when test="$lang = 'ar' and $align = 'left'">start</xsl:when>
+ <xsl:when test="$lang = 'ar' and $align = 'right'">end</xsl:when>
+ <xsl:when test="$align != '' and not($align = 'indent')"><xsl:value-of select="$align"/></xsl:when>
<xsl:when test="ancestor::*[local-name() = 'td']/@align"><xsl:value-of select="ancestor::*[local-name() = 'td']/@align"/></xsl:when>
<xsl:when test="ancestor::*[local-name() = 'th']/@align"><xsl:value-of select="ancestor::*[local-name() = 'th']/@align"/></xsl:when>
<xsl:otherwise><xsl:value-of select="$default"/></xsl:otherwise>
</xsl:choose>
</xsl:attribute>
- <xsl:if test="@align = 'indent'">
+ <xsl:if test="$align = 'indent'">
<xsl:attribute name="margin-left">7mm</xsl:attribute>
</xsl:if>
</xsl:template><xsl:template name="number-to-words">
<xsl:param name="number"/>
<xsl:param name="first"/>
\ No newline at end of file