metanorma-iso 3.0.1 → 3.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3229,11 +3229,11 @@
3229
3229
 
3230
3230
  <xsl:if test="count(*) = 1 and *[local-name() = 'title']"> <!-- if there isn't user ToC -->
3231
3231
 
3232
- <!-- <xsl:if test="$debug = 'true'">
3232
+ <xsl:if test="$debug = 'true'">
3233
3233
  <redirect:write file="contents_.xml">
3234
3234
  <xsl:copy-of select="$contents"/>
3235
3235
  </redirect:write>
3236
- </xsl:if> -->
3236
+ </xsl:if>
3237
3237
 
3238
3238
  <xsl:variable name="margin-left">12</xsl:variable>
3239
3239
 
@@ -4410,10 +4410,6 @@
4410
4410
 
4411
4411
  </xsl:template>
4412
4412
 
4413
- <xsl:template match="iso:p/iso:fn/iso:p">
4414
- <xsl:apply-templates/>
4415
- </xsl:template>
4416
-
4417
4413
  <!-- For express listings PDF attachments -->
4418
4414
  <xsl:template match="*[local-name() = 'eref'][java:endsWith(java:java.lang.String.new(@bibitemid),'.exp')]" priority="2">
4419
4415
  <fo:inline xsl:use-attribute-sets="eref-style">
@@ -6633,14 +6629,18 @@
6633
6629
  </xsl:template>
6634
6630
 
6635
6631
  <xsl:attribute-set name="table-fn-number-style">
6632
+ <!-- <xsl:attribute name="padding-right">5mm</xsl:attribute> -->
6633
+
6634
+ </xsl:attribute-set> <!-- table-fn-number-style -->
6635
+
6636
+ <xsl:attribute-set name="table-fmt-fn-label-style">
6636
6637
  <xsl:attribute name="font-size">80%</xsl:attribute>
6637
- <xsl:attribute name="padding-right">5mm</xsl:attribute>
6638
6638
 
6639
6639
  <xsl:attribute name="alignment-baseline">hanging</xsl:attribute>
6640
6640
 
6641
- </xsl:attribute-set> <!-- table-fn-number-style -->
6641
+ </xsl:attribute-set> <!-- table-fmt-fn-label-style -->
6642
6642
 
6643
- <xsl:template name="refine_table-fn-number-style">
6643
+ <xsl:template name="refine_table-fmt-fn-label-style">
6644
6644
 
6645
6645
  <xsl:if test="$layoutVersion = '2024'">
6646
6646
  <xsl:attribute name="alignment-baseline">auto</xsl:attribute>
@@ -6660,11 +6660,18 @@
6660
6660
  </xsl:attribute-set>
6661
6661
 
6662
6662
  <xsl:attribute-set name="figure-fn-number-style">
6663
- <xsl:attribute name="font-size">80%</xsl:attribute>
6664
6663
  <xsl:attribute name="padding-right">5mm</xsl:attribute>
6664
+ </xsl:attribute-set> <!-- figure-fn-number-style -->
6665
+
6666
+ <xsl:attribute-set name="figure-fmt-fn-label-style">
6667
+ <xsl:attribute name="font-size">80%</xsl:attribute>
6665
6668
  <xsl:attribute name="vertical-align">super</xsl:attribute>
6666
6669
 
6667
- </xsl:attribute-set>
6670
+ </xsl:attribute-set> <!-- figure-fmt-fn-label-style -->
6671
+
6672
+ <xsl:template name="refine_figure-fmt-fn-label-style">
6673
+
6674
+ </xsl:template>
6668
6675
 
6669
6676
  <xsl:attribute-set name="figure-fn-body-style">
6670
6677
  <xsl:attribute name="text-align">justify</xsl:attribute>
@@ -8267,9 +8274,13 @@
8267
8274
 
8268
8275
  <xsl:variable name="isNoteOrFnExist" select="./*[local-name()='note'][not(@type = 'units')] or ./*[local-name()='example'] or .//*[local-name()='fn'][local-name(..) != 'name'] or ./*[local-name()='source']"/>
8269
8276
  <xsl:if test="$isNoteOrFnExist = 'true'">
8270
-
8271
- <xsl:attribute name="border-bottom">0pt solid black</xsl:attribute><!-- set 0pt border, because there is a separete table below for footer -->
8272
-
8277
+ <!-- <xsl:choose>
8278
+ <xsl:when test="$namespace = 'plateau'"></xsl:when>
8279
+ <xsl:otherwise>
8280
+
8281
+ </xsl:otherwise>
8282
+ </xsl:choose> -->
8283
+ <xsl:attribute name="border-bottom">0pt solid black</xsl:attribute><!-- set 0pt border, because there is a separete table below for footer -->
8273
8284
  </xsl:if>
8274
8285
 
8275
8286
  <xsl:choose>
@@ -8316,7 +8327,7 @@
8316
8327
  <xsl:apply-templates select="*[local-name()='thead']" mode="process_tbody"/>
8317
8328
  </xsl:when>
8318
8329
  <xsl:otherwise>
8319
- <xsl:apply-templates select="node()[not(local-name() = 'name') and not(local-name() = 'note') and not(local-name() = 'example') and not(local-name() = 'dl') and not(local-name() = 'source') and not(local-name() = 'p') and not(local-name() = 'thead') and not(local-name() = 'tfoot')]"/> <!-- process all table' elements, except name, header, footer, note, source and dl which render separaterely -->
8330
+ <xsl:apply-templates select="node()[not(local-name() = 'name') and not(local-name() = 'note') and not(local-name() = 'example') and not(local-name() = 'dl') and not(local-name() = 'source') and not(local-name() = 'p') and not(local-name() = 'thead') and not(local-name() = 'tfoot') and not(local-name() = 'fmt-footnote-container')]"/> <!-- process all table' elements, except name, header, footer, note, source and dl which render separaterely -->
8320
8331
  </xsl:otherwise>
8321
8332
  </xsl:choose>
8322
8333
 
@@ -8327,13 +8338,26 @@
8327
8338
 
8328
8339
  <xsl:variable name="colgroup" select="*[local-name()='colgroup']"/>
8329
8340
 
8330
- <xsl:for-each select="*[local-name()='tbody']"><!-- select context to tbody -->
8331
- <xsl:call-template name="insertTableFooterInSeparateTable">
8332
- <xsl:with-param name="table_attributes" select="$table_attributes"/>
8333
- <xsl:with-param name="colwidths" select="$colwidths"/>
8334
- <xsl:with-param name="colgroup" select="$colgroup"/>
8335
- </xsl:call-template>
8336
- </xsl:for-each>
8341
+ <!-- https://github.com/metanorma/metanorma-plateau/issues/171 -->
8342
+
8343
+ <xsl:for-each select="*[local-name()='tbody']"><!-- select context to tbody -->
8344
+ <xsl:call-template name="insertTableFooterInSeparateTable">
8345
+ <xsl:with-param name="table_attributes" select="$table_attributes"/>
8346
+ <xsl:with-param name="colwidths" select="$colwidths"/>
8347
+ <xsl:with-param name="colgroup" select="$colgroup"/>
8348
+ </xsl:call-template>
8349
+ </xsl:for-each>
8350
+
8351
+ <!-- https://github.com/metanorma/metanorma-plateau/issues/171
8352
+ <xsl:if test="$namespace = 'plateau'">
8353
+ <xsl:apply-templates select="*[not(local-name()='thead') and not(local-name()='tbody') and not(local-name()='tfoot') and not(local-name()='name')]" />
8354
+ <xsl:for-each select="*[local-name()='tbody']"> - select context to tbody -
8355
+ <xsl:variable name="table_fn_block">
8356
+ <xsl:call-template name="table_fn_display" />
8357
+ </xsl:variable>
8358
+ <xsl:copy-of select="$table_fn_block"/>
8359
+ </xsl:for-each>
8360
+ </xsl:if> -->
8337
8361
 
8338
8362
  <xsl:if test="*[local-name()='bookmark']"> <!-- special case: table/bookmark -->
8339
8363
  <fo:block keep-with-previous="always" line-height="0.1">
@@ -9048,6 +9072,7 @@
9048
9072
  <xsl:with-param name="key">continued</xsl:with-param>
9049
9073
  </xsl:call-template>
9050
9074
  </xsl:variable>
9075
+
9051
9076
  <xsl:variable name="title_continued_in_parenthesis" select="concat('(',$title_continued_,')')"/>
9052
9077
  <xsl:variable name="title_continued">
9053
9078
  <xsl:value-of select="$title_continued_in_parenthesis"/>
@@ -9201,6 +9226,8 @@
9201
9226
 
9202
9227
  <xsl:template name="setTableRowAttributes">
9203
9228
 
9229
+ <xsl:call-template name="setColors"/>
9230
+
9204
9231
  </xsl:template> <!-- setTableRowAttributes -->
9205
9232
  <!-- ===================== -->
9206
9233
  <!-- END Table's row processing -->
@@ -9252,6 +9279,7 @@
9252
9279
  </xsl:attribute>
9253
9280
  </xsl:if>
9254
9281
  <xsl:call-template name="display-align"/>
9282
+ <xsl:call-template name="setColors"/>
9255
9283
  </xsl:template>
9256
9284
 
9257
9285
  <xsl:template name="display-align">
@@ -9267,6 +9295,29 @@
9267
9295
  </xsl:if>
9268
9296
  </xsl:template>
9269
9297
 
9298
+ <xsl:template name="setColors">
9299
+ <xsl:variable name="styles__">
9300
+ <xsl:call-template name="split">
9301
+ <xsl:with-param name="pText" select="concat(@style,';')"/>
9302
+ <xsl:with-param name="sep" select="';'"/>
9303
+ </xsl:call-template>
9304
+ </xsl:variable>
9305
+ <xsl:variable name="quot">"</xsl:variable>
9306
+ <xsl:variable name="styles_">
9307
+ <xsl:for-each select="xalan:nodeset($styles__)/item">
9308
+ <xsl:variable name="key" select="normalize-space(substring-before(., ':'))"/>
9309
+ <xsl:variable name="value" select="normalize-space(substring-after(translate(.,$quot,''), ':'))"/>
9310
+ <xsl:if test="$key = 'color' or $key = 'background-color'">
9311
+ <style name="{$key}"><xsl:value-of select="$value"/></style>
9312
+ </xsl:if>
9313
+ </xsl:for-each>
9314
+ </xsl:variable>
9315
+ <xsl:variable name="styles" select="xalan:nodeset($styles_)"/>
9316
+ <xsl:for-each select="$styles/style">
9317
+ <xsl:attribute name="{@name}"><xsl:value-of select="."/></xsl:attribute>
9318
+ </xsl:for-each>
9319
+ </xsl:template>
9320
+
9270
9321
  <!-- cell in table body, footer -->
9271
9322
  <xsl:template match="*[local-name()='td']" name="td">
9272
9323
  <fo:table-cell xsl:use-attribute-sets="table-cell-style"> <!-- text-align="{@align}" -->
@@ -9278,17 +9329,28 @@
9278
9329
 
9279
9330
  <xsl:call-template name="refine_table-cell-style"/>
9280
9331
 
9332
+ <xsl:call-template name="setTableCellAttributes"/>
9333
+
9281
9334
  <xsl:if test=".//*[local-name() = 'table']"> <!-- if there is nested table -->
9282
9335
  <xsl:attribute name="padding-right">1mm</xsl:attribute>
9283
9336
  </xsl:if>
9284
9337
 
9285
- <xsl:call-template name="setTableCellAttributes"/>
9286
-
9287
9338
  <xsl:if test="$isGenerateTableIF = 'true'">
9288
9339
  <xsl:attribute name="border">1pt solid black</xsl:attribute> <!-- border is mandatory, to determine page width -->
9289
9340
  <xsl:attribute name="text-align">left</xsl:attribute>
9290
9341
  </xsl:if>
9291
9342
 
9343
+ <xsl:if test="$isGenerateTableIF = 'false'">
9344
+ <xsl:if test="@colspan and *[local-name() = 'note'][@type = 'units']">
9345
+ <xsl:attribute name="text-align">right</xsl:attribute>
9346
+ <xsl:attribute name="border">none</xsl:attribute>
9347
+ <xsl:attribute name="border-bottom"><xsl:value-of select="$table-border"/></xsl:attribute>
9348
+ <xsl:attribute name="border-top">1pt solid white</xsl:attribute>
9349
+ <xsl:attribute name="border-left">1pt solid white</xsl:attribute>
9350
+ <xsl:attribute name="border-right">1pt solid white</xsl:attribute>
9351
+ </xsl:if>
9352
+ </xsl:if>
9353
+
9292
9354
  <fo:block role="SKIP">
9293
9355
 
9294
9356
  <xsl:if test="$isGenerateTableIF = 'true'">
@@ -9307,7 +9369,8 @@
9307
9369
  </fo:table-cell>
9308
9370
  </xsl:template> <!-- td -->
9309
9371
 
9310
- <xsl:template match="*[local-name()='table']/*[local-name()='note' or local-name() = 'example']" priority="2">
9372
+ <!-- table/note, table/example, table/tfoot//note, table/tfoot//example -->
9373
+ <xsl:template match="*[local-name()='table']/*[local-name()='note' or local-name() = 'example'] | *[local-name()='table']/*[local-name()='tfoot']//*[local-name()='note' or local-name() = 'example']" priority="2">
9311
9374
 
9312
9375
  <fo:block xsl:use-attribute-sets="table-note-style">
9313
9376
  <xsl:copy-of select="@id"/>
@@ -9328,51 +9391,46 @@
9328
9391
 
9329
9392
  </xsl:template> <!-- table/note -->
9330
9393
 
9331
- <xsl:template match="*[local-name()='table']/*[local-name()='note' or local-name()='example']/*[local-name()='p']" priority="2">
9394
+ <xsl:template match="*[local-name()='table']/*[local-name()='note' or local-name()='example']/*[local-name()='p'] | *[local-name()='table']/*[local-name()='tfoot']//*[local-name()='note' or local-name()='example']/*[local-name()='p']" priority="2">
9332
9395
  <xsl:apply-templates/>
9333
9396
  </xsl:template>
9334
9397
 
9335
9398
  <!-- ===================== -->
9336
9399
  <!-- Footnotes processing -->
9337
9400
  <!-- ===================== -->
9401
+
9402
+ <!-- document text (not figures, or tables) footnotes -->
9403
+ <xsl:variable name="footnotes_">
9404
+ <xsl:for-each select="//*[local-name() = 'fmt-footnote-container']/*[local-name() = 'fmt-fn-body']"> <!-- commented *[local-name() = 'metanorma']/, because there are fn in figure or table name -->
9405
+ <!-- <xsl:copy-of select="."/> -->
9406
+ <xsl:variable name="update_xml_step1">
9407
+ <xsl:apply-templates select="." mode="update_xml_step1"/>
9408
+ </xsl:variable>
9409
+ <xsl:apply-templates select="xalan:nodeset($update_xml_step1)" mode="update_xml_enclose_keep-together_within-line"/>
9410
+ </xsl:for-each>
9411
+ </xsl:variable>
9412
+ <xsl:variable name="footnotes" select="xalan:nodeset($footnotes_)"/>
9413
+
9338
9414
  <!--
9339
9415
  <fn reference="1">
9340
9416
  <p id="_8e5cf917-f75a-4a49-b0aa-1714cb6cf954">Formerly denoted as 15 % (m/m).</p>
9341
9417
  </fn>
9342
9418
  -->
9343
- <!-- footnotes in text (title, bibliography, main body, table's, figure's names), not for tables, figures -->
9419
+ <!-- footnotes in text (title, bibliography, main body), not for tables, figures and names --> <!-- table's, figure's names -->
9420
+ <!-- fn in text -->
9344
9421
  <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">
9345
9422
 
9346
- <!-- list of footnotes to calculate actual footnotes number -->
9423
+ <!-- list of unique footnotes -->
9347
9424
  <xsl:variable name="p_fn_">
9348
9425
  <xsl:call-template name="get_fn_list"/>
9349
- <!-- <xsl:choose>
9350
- <xsl:when test="$namespace = 'jis'">
9351
- <xsl:call-template name="get_fn_list_for_element"/>
9352
- </xsl:when>
9353
- <xsl:otherwise>
9354
- <xsl:call-template name="get_fn_list"/>
9355
- </xsl:otherwise>
9356
- </xsl:choose> -->
9357
9426
  </xsl:variable>
9358
9427
  <xsl:variable name="p_fn" select="xalan:nodeset($p_fn_)"/>
9359
9428
 
9360
9429
  <xsl:variable name="gen_id" select="generate-id(.)"/>
9361
- <xsl:variable name="lang" select="ancestor::*[local-name() = 'metanorma']/*[local-name()='bibdata']//*[local-name()='language'][@current = 'true']"/>
9362
- <xsl:variable name="reference_">
9363
- <xsl:value-of select="@reference"/>
9364
- <xsl:if test="normalize-space(@reference) = ''"><xsl:value-of select="$gen_id"/></xsl:if>
9365
- </xsl:variable>
9366
- <xsl:variable name="reference" select="normalize-space($reference_)"/>
9430
+
9367
9431
  <!-- fn sequence number in document -->
9368
- <xsl:variable name="current_fn_number">
9369
- <xsl:choose>
9370
- <xsl:when test="@current_fn_number"><xsl:value-of select="@current_fn_number"/></xsl:when> <!-- for BSI -->
9371
- <xsl:otherwise>
9372
- <xsl:value-of select="count($p_fn//fn[@reference = $reference]/preceding-sibling::fn) + 1"/>
9373
- </xsl:otherwise>
9374
- </xsl:choose>
9375
- </xsl:variable>
9432
+ <xsl:variable name="current_fn_number" select="@reference"/>
9433
+
9376
9434
  <xsl:variable name="current_fn_number_text">
9377
9435
 
9378
9436
  <xsl:choose>
@@ -9383,19 +9441,13 @@
9383
9441
  <xsl:with-param name="count" select="$current_fn_number"/>
9384
9442
  </xsl:call-template>
9385
9443
  </xsl:when>
9386
- <xsl:otherwise><xsl:value-of select="$current_fn_number"/><xsl:text>)</xsl:text></xsl:otherwise>
9444
+ <xsl:otherwise><xsl:value-of select="normalize-space(*[local-name() = 'fmt-fn-label'])"/></xsl:otherwise>
9387
9445
  </xsl:choose>
9388
9446
 
9389
9447
  </xsl:variable>
9390
9448
 
9391
- <xsl:variable name="ref_id">
9392
- <xsl:choose>
9393
- <xsl:when test="normalize-space(@ref_id) != ''"><xsl:value-of select="@ref_id"/></xsl:when>
9394
- <xsl:otherwise>
9395
- <xsl:value-of select="concat('footnote_', $lang, '_', $reference, '_', $current_fn_number)"/>
9396
- </xsl:otherwise>
9397
- </xsl:choose>
9398
- </xsl:variable>
9449
+ <xsl:variable name="ref_id" select="@target"/>
9450
+
9399
9451
  <xsl:variable name="footnote_inline">
9400
9452
  <fo:inline role="Reference">
9401
9453
 
@@ -9444,7 +9496,9 @@
9444
9496
  <xsl:when test="normalize-space(@skip_footnote_body) = 'true'">
9445
9497
  <xsl:copy-of select="$footnote_inline"/>
9446
9498
  </xsl:when>
9499
+ <!-- <xsl:when test="$footnotes//*[local-name() = 'fmt-fn-body'][@id = $ref_id] or normalize-space(@skip_footnote_body) = 'false'"> -->
9447
9500
  <xsl:when test="$p_fn//fn[@gen_id = $gen_id] or normalize-space(@skip_footnote_body) = 'false'">
9501
+
9448
9502
  <fo:footnote xsl:use-attribute-sets="fn-style" role="SKIP">
9449
9503
  <xsl:copy-of select="$footnote_inline"/>
9450
9504
  <fo:footnote-body role="Note">
@@ -9461,7 +9515,10 @@
9461
9515
  <xsl:value-of select="$current_fn_number_text"/>
9462
9516
 
9463
9517
  </fo:inline>
9464
- <xsl:apply-templates/>
9518
+ <!-- <xsl:apply-templates /> -->
9519
+ <!-- <ref_id><xsl:value-of select="$ref_id"/></ref_id>
9520
+ <here><xsl:copy-of select="$footnotes"/></here> -->
9521
+ <xsl:apply-templates select="$footnotes/*[local-name() = 'fmt-fn-body'][@id = $ref_id]"/>
9465
9522
  </xsl:variable>
9466
9523
 
9467
9524
  <fo:block xsl:use-attribute-sets="fn-body-style" role="SKIP">
@@ -9515,77 +9572,136 @@
9515
9572
  </xsl:choose>
9516
9573
  </xsl:template>
9517
9574
 
9518
- <xsl:template name="get_fn_list_for_element">
9519
- <xsl:choose>
9520
- <xsl:when test="@current_fn_number"> <!-- footnote reference number calculated already -->
9521
- <fn gen_id="{generate-id(.)}">
9522
- <xsl:copy-of select="@*"/>
9523
- <xsl:copy-of select="node()"/>
9524
- </fn>
9525
- </xsl:when>
9526
- <xsl:otherwise>
9527
- <xsl:for-each select="ancestor::*[local-name() = 'ul' or local-name() = 'ol'][1]">
9528
- <xsl:variable name="element_id" select="@id"/>
9529
- <xsl:for-each select=".//*[local-name() = 'fn'][generate-id(.)=generate-id(key('kfn',@reference)[1])]">
9530
- <!-- copy unique fn -->
9531
- <fn gen_id="{generate-id(.)}">
9532
- <xsl:copy-of select="@*"/>
9533
- <xsl:copy-of select="node()"/>
9534
- </fn>
9535
- </xsl:for-each>
9536
- </xsl:for-each>
9537
- </xsl:otherwise>
9538
- </xsl:choose>
9539
- </xsl:template>
9540
9575
  <!-- ============================ -->
9541
9576
  <!-- table's footnotes rendering -->
9542
9577
  <!-- ============================ -->
9543
- <xsl:template name="table_fn_display">
9544
- <xsl:variable name="references">
9545
9578
 
9579
+ <!-- table/fmt-footnote-container -->
9580
+ <xsl:template match="*[local-name() = 'table']/*[local-name() = 'fmt-footnote-container']"/>
9581
+
9582
+ <xsl:template match="*[local-name() = 'table']/*[local-name() = 'tfoot']//*[local-name() = 'fmt-footnote-container']">
9583
+ <xsl:for-each select=".">
9584
+ <xsl:call-template name="table_fn_display"/>
9585
+ </xsl:for-each>
9586
+ </xsl:template>
9587
+
9588
+ <xsl:template name="table_fn_display">
9589
+ <!-- <xsl:variable name="references">
9590
+ <xsl:if test="$namespace = 'bsi'">
9591
+ <xsl:for-each select="..//*[local-name()='fn'][local-name(..) = 'name']">
9592
+ <xsl:call-template name="create_fn" />
9593
+ </xsl:for-each>
9594
+ </xsl:if>
9546
9595
  <xsl:for-each select="..//*[local-name()='fn'][local-name(..) != 'name']">
9547
- <xsl:call-template name="create_fn"/>
9596
+ <xsl:call-template name="create_fn" />
9548
9597
  </xsl:for-each>
9549
- </xsl:variable>
9550
-
9551
- <xsl:for-each select="xalan:nodeset($references)//fn">
9598
+ </xsl:variable> -->
9599
+ <!-- <xsl:for-each select="xalan:nodeset($references)//fn">
9552
9600
  <xsl:variable name="reference" select="@reference"/>
9553
- <xsl:if test="not(preceding-sibling::*[@reference = $reference])"> <!-- only unique reference puts in note-->
9601
+ <xsl:if test="not(preceding-sibling::*[@reference = $reference])"> --> <!-- only unique reference puts in note-->
9602
+ <xsl:for-each select="..//*[local-name() = 'fmt-footnote-container']/*[local-name() = 'fmt-fn-body']">
9554
9603
 
9555
9604
  <fo:block xsl:use-attribute-sets="table-fn-style">
9605
+ <xsl:copy-of select="@id"/>
9556
9606
  <xsl:call-template name="refine_table-fn-style"/>
9557
- <fo:inline id="{@id}" xsl:use-attribute-sets="table-fn-number-style">
9558
- <xsl:call-template name="refine_table-fn-number-style"/>
9559
9607
 
9560
- <xsl:value-of select="@reference"/>
9561
-
9562
- <!-- commented https://github.com/metanorma/isodoc/issues/614 -->
9563
- <!-- <xsl:if test="$namespace = 'itu'">
9564
- <xsl:text>)</xsl:text>
9565
- </xsl:if> -->
9608
+ <xsl:apply-templates select=".//*[local-name() = 'fmt-fn-label']">
9609
+ <xsl:with-param name="process">true</xsl:with-param>
9610
+ </xsl:apply-templates>
9566
9611
 
9567
- </fo:inline>
9568
9612
  <fo:inline xsl:use-attribute-sets="table-fn-body-style">
9569
- <xsl:copy-of select="./node()"/>
9613
+ <!-- <xsl:copy-of select="./node()"/> -->
9614
+ <xsl:apply-templates/>
9570
9615
  </fo:inline>
9571
9616
 
9572
9617
  </fo:block>
9573
9618
 
9574
- </xsl:if>
9619
+ <!-- </xsl:if> -->
9575
9620
  </xsl:for-each>
9576
9621
  </xsl:template> <!-- table_fn_display -->
9577
9622
 
9623
+ <!-- fmt-fn-body/fmt-fn-label in text -->
9624
+ <xsl:template match="*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']"/>
9625
+
9626
+ <!-- table//fmt-fn-body//fmt-fn-label -->
9627
+ <xsl:template match="*[local-name() = 'table']//*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']"> <!-- *[local-name() = 'fmt-footnote-container']/ -->
9628
+ <xsl:param name="process">false</xsl:param>
9629
+ <xsl:if test="$process = 'true'">
9630
+ <fo:inline xsl:use-attribute-sets="table-fn-number-style" role="SKIP">
9631
+
9632
+ <!-- tab is padding-right -->
9633
+ <xsl:apply-templates select=".//*[local-name() = 'tab']">
9634
+ <xsl:with-param name="process">true</xsl:with-param>
9635
+ </xsl:apply-templates>
9636
+
9637
+ <!-- <xsl:if test="$namespace = 'bipm'">
9638
+ <fo:inline font-style="normal">(</fo:inline>
9639
+ </xsl:if> -->
9640
+
9641
+ <!-- <xsl:if test="$namespace = 'plateau'">
9642
+ <xsl:text>※</xsl:text>
9643
+ </xsl:if> -->
9644
+
9645
+ <!-- <xsl:value-of select="@reference"/> -->
9646
+ <!-- <xsl:value-of select="normalize-space()"/> -->
9647
+ <xsl:apply-templates/>
9648
+
9649
+ <!-- <xsl:if test="$namespace = 'bipm'">
9650
+ <fo:inline font-style="normal">)</fo:inline>
9651
+ </xsl:if> -->
9652
+
9653
+ <!-- commented https://github.com/metanorma/isodoc/issues/614 -->
9654
+ <!-- <xsl:if test="$namespace = 'itu'">
9655
+ <xsl:text>)</xsl:text>
9656
+ </xsl:if> -->
9657
+
9658
+ <!-- <xsl:if test="$namespace = 'plateau'">
9659
+ <xsl:text>:</xsl:text>
9660
+ </xsl:if> -->
9661
+
9662
+ </fo:inline>
9663
+ </xsl:if>
9664
+ </xsl:template> <!-- fmt-fn-body//fmt-fn-label -->
9665
+
9666
+ <xsl:template match="*[local-name() = 'table']//*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']//*[local-name() = 'tab']" priority="5">
9667
+ <xsl:param name="process">false</xsl:param>
9668
+ <xsl:if test="$process = 'true'">
9669
+ <xsl:attribute name="padding-right">5mm</xsl:attribute>
9670
+
9671
+ </xsl:if>
9672
+ </xsl:template>
9673
+
9674
+ <xsl:template match="*[local-name() = 'table']//*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']//*[local-name() = 'sup']" priority="5">
9675
+ <fo:inline xsl:use-attribute-sets="table-fmt-fn-label-style" role="SKIP">
9676
+ <xsl:call-template name="refine_table-fmt-fn-label-style"/>
9677
+ <xsl:apply-templates/>
9678
+ </fo:inline>
9679
+ </xsl:template>
9680
+
9681
+ <!-- <xsl:template match="*[local-name() = 'fmt-footnote-container']/*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']//*[local-name() = 'tab']"/> -->
9682
+ <!--
9578
9683
  <xsl:template name="create_fn">
9579
9684
  <fn reference="{@reference}" id="{@reference}_{ancestor::*[@id][1]/@id}">
9580
- <xsl:if test="ancestor::*[local-name()='table'][1]/@id"> <!-- for footnotes in tables -->
9685
+ <xsl:if test="ancestor::*[local-name()='table'][1]/@id"> - for footnotes in tables -
9581
9686
  <xsl:attribute name="id">
9582
9687
  <xsl:value-of select="concat(@reference, '_', ancestor::*[local-name()='table'][1]/@id)"/>
9583
9688
  </xsl:attribute>
9584
9689
  </xsl:if>
9585
-
9586
- <xsl:apply-templates/>
9690
+ <xsl:if test="$namespace = 'itu'">
9691
+ <xsl:if test="ancestor::*[local-name()='preface']">
9692
+ <xsl:attribute name="preface">true</xsl:attribute>
9693
+ </xsl:if>
9694
+ </xsl:if>
9695
+ <xsl:if test="$namespace = 'ogc' or $namespace = 'ogc-white-paper'">
9696
+ <xsl:attribute name="id">
9697
+ <xsl:value-of select="@reference"/>
9698
+ <xsl:text>_</xsl:text>
9699
+ <xsl:value-of select="ancestor::*[local-name()='table'][1]/@id"/>
9700
+ </xsl:attribute>
9701
+ </xsl:if>
9702
+ <xsl:apply-templates />
9587
9703
  </fn>
9588
- </xsl:template>
9704
+ </xsl:template> -->
9589
9705
 
9590
9706
  <!-- footnotes for table's name rendering -->
9591
9707
  <xsl:template name="table_name_fn_display">
@@ -9604,123 +9720,171 @@
9604
9720
  <!-- ============================ -->
9605
9721
  <!-- figure's footnotes rendering -->
9606
9722
  <!-- ============================ -->
9607
- <xsl:template name="fn_display_figure"> <!-- figure_fn_display -->
9608
9723
 
9609
- <!-- current figure id -->
9610
- <xsl:variable name="figure_id_">
9611
- <xsl:value-of select="@id"/>
9612
- <xsl:if test="not(@id)"><xsl:value-of select="generate-id()"/></xsl:if>
9613
- </xsl:variable>
9614
- <xsl:variable name="figure_id" select="normalize-space($figure_id_)"/>
9724
+ <!-- figure/fmt-footnote-container -->
9725
+ <xsl:template match="*[local-name() = 'figure']//*[local-name() = 'fmt-footnote-container']"/>
9726
+
9727
+ <!-- TO DO: remove, now the figure fn in figure/dl/... https://github.com/metanorma/isodoc/issues/658 -->
9728
+ <xsl:template name="figure_fn_display">
9615
9729
 
9616
- <!-- all footnotes relates to the current figure -->
9617
9730
  <xsl:variable name="references">
9618
- <xsl:for-each select=".//*[local-name()='fn'][not(parent::*[local-name()='name'])][ancestor::*[local-name() = 'figure'][1][@id = $figure_id]]">
9619
- <fn reference="{@reference}" id="{@reference}_{ancestor::*[@id][1]/@id}">
9620
- <xsl:apply-templates/>
9621
- </fn>
9731
+ <xsl:for-each select="./*[local-name() = 'fmt-footnote-container']/*[local-name() = 'fmt-fn-body']">
9732
+ <xsl:variable name="curr_id" select="@id"/>
9733
+ <!-- <curr_id><xsl:value-of select="$curr_id"/></curr_id>
9734
+ <curr><xsl:copy-of select="."/></curr>
9735
+ <ancestor><xsl:copy-of select="ancestor::*[local-name() = 'figure'][.//*[local-name() = 'name'][.//*[local-name() = 'fn']]]"/></ancestor> -->
9736
+ <xsl:choose>
9737
+ <!-- skip figure/name/fn -->
9738
+ <xsl:when test="ancestor::*[local-name() = 'figure'][.//*[local-name() = 'name'][.//*[local-name() = 'fn'][@target = $curr_id]]]"><!-- skip --></xsl:when>
9739
+ <xsl:otherwise>
9740
+ <xsl:element name="figure" namespace="{$namespace_full}">
9741
+ <xsl:element name="fmt-footnote-container" namespace="{$namespace_full}">
9742
+ <xsl:copy-of select="."/>
9743
+ </xsl:element>
9744
+ </xsl:element>
9745
+ </xsl:otherwise>
9746
+ </xsl:choose>
9622
9747
  </xsl:for-each>
9623
9748
  </xsl:variable>
9749
+ <!-- <references><xsl:copy-of select="$references"/></references> -->
9624
9750
 
9625
- <xsl:if test="xalan:nodeset($references)//fn">
9751
+ <xsl:if test="xalan:nodeset($references)//*[local-name() = 'fmt-fn-body']">
9626
9752
 
9627
9753
  <xsl:variable name="key_iso">
9628
9754
  true
9629
9755
  </xsl:variable>
9630
9756
 
9631
9757
  <fo:block>
9758
+ <!-- current hierarchy is 'figure' element -->
9759
+ <xsl:variable name="following_dl_colwidths">
9760
+ <xsl:if test="*[local-name() = 'dl']"><!-- if there is a 'dl', then set the same columns width as for 'dl' -->
9761
+ <xsl:variable name="simple-table">
9762
+ <!-- <xsl:variable name="doc_ns">
9763
+ <xsl:if test="$namespace = 'bipm'">bipm</xsl:if>
9764
+ </xsl:variable>
9765
+ <xsl:variable name="ns">
9766
+ <xsl:choose>
9767
+ <xsl:when test="normalize-space($doc_ns) != ''">
9768
+ <xsl:value-of select="normalize-space($doc_ns)"/>
9769
+ </xsl:when>
9770
+ <xsl:otherwise>
9771
+ <xsl:value-of select="substring-before(name(/*), '-')"/>
9772
+ </xsl:otherwise>
9773
+ </xsl:choose>
9774
+ </xsl:variable> -->
9632
9775
 
9633
- <!-- current hierarchy is 'figure' element -->
9634
- <xsl:variable name="following_dl_colwidths">
9635
- <xsl:if test="*[local-name() = 'dl']"><!-- if there is a 'dl', then set the same columns width as for 'dl' -->
9636
- <xsl:variable name="simple-table">
9637
- <!-- <xsl:variable name="doc_ns">
9638
- <xsl:if test="$namespace = 'bipm'">bipm</xsl:if>
9639
- </xsl:variable>
9640
- <xsl:variable name="ns">
9641
- <xsl:choose>
9642
- <xsl:when test="normalize-space($doc_ns) != ''">
9643
- <xsl:value-of select="normalize-space($doc_ns)"/>
9644
- </xsl:when>
9645
- <xsl:otherwise>
9646
- <xsl:value-of select="substring-before(name(/*), '-')"/>
9647
- </xsl:otherwise>
9648
- </xsl:choose>
9649
- </xsl:variable> -->
9776
+ <xsl:for-each select="*[local-name() = 'dl'][1]">
9777
+ <tbody>
9778
+ <xsl:apply-templates mode="dl"/>
9779
+ </tbody>
9780
+ </xsl:for-each>
9781
+ </xsl:variable>
9650
9782
 
9651
- <xsl:for-each select="*[local-name() = 'dl'][1]">
9652
- <tbody>
9653
- <xsl:apply-templates mode="dl"/>
9654
- </tbody>
9655
- </xsl:for-each>
9656
- </xsl:variable>
9783
+ <xsl:call-template name="calculate-column-widths">
9784
+ <xsl:with-param name="cols-count" select="2"/>
9785
+ <xsl:with-param name="table" select="$simple-table"/>
9786
+ </xsl:call-template>
9657
9787
 
9658
- <xsl:call-template name="calculate-column-widths">
9659
- <xsl:with-param name="cols-count" select="2"/>
9660
- <xsl:with-param name="table" select="$simple-table"/>
9661
- </xsl:call-template>
9788
+ </xsl:if>
9789
+ </xsl:variable>
9662
9790
 
9663
- </xsl:if>
9664
- </xsl:variable>
9791
+ <xsl:variable name="maxlength_dt">
9792
+ <xsl:for-each select="*[local-name() = 'dl'][1]">
9793
+ <xsl:call-template name="getMaxLength_dt"/>
9794
+ </xsl:for-each>
9795
+ </xsl:variable>
9665
9796
 
9666
- <xsl:variable name="maxlength_dt">
9667
- <xsl:for-each select="*[local-name() = 'dl'][1]">
9668
- <xsl:call-template name="getMaxLength_dt"/>
9669
- </xsl:for-each>
9670
- </xsl:variable>
9797
+ <fo:table width="95%" table-layout="fixed">
9798
+ <xsl:if test="normalize-space($key_iso) = 'true'">
9799
+ <xsl:attribute name="font-size">10pt</xsl:attribute>
9671
9800
 
9672
- <fo:table width="95%" table-layout="fixed">
9673
- <xsl:if test="normalize-space($key_iso) = 'true'">
9674
- <xsl:attribute name="font-size">10pt</xsl:attribute>
9801
+ </xsl:if>
9802
+ <xsl:choose>
9803
+ <!-- if there 'dl', then set same columns width -->
9804
+ <xsl:when test="xalan:nodeset($following_dl_colwidths)//column">
9805
+ <xsl:call-template name="setColumnWidth_dl">
9806
+ <xsl:with-param name="colwidths" select="$following_dl_colwidths"/>
9807
+ <xsl:with-param name="maxlength_dt" select="$maxlength_dt"/>
9808
+ </xsl:call-template>
9809
+ </xsl:when>
9810
+ <xsl:otherwise>
9811
+ <fo:table-column column-width="5%"/>
9812
+ <fo:table-column column-width="95%"/>
9813
+ </xsl:otherwise>
9814
+ </xsl:choose>
9815
+ <fo:table-body>
9816
+ <!-- <xsl:for-each select="xalan:nodeset($references)//fn"> -->
9817
+ <xsl:for-each select="xalan:nodeset($references)//*[local-name() = 'fmt-fn-body']">
9675
9818
 
9676
- </xsl:if>
9677
- <xsl:choose>
9678
- <!-- if there 'dl', then set same columns width -->
9679
- <xsl:when test="xalan:nodeset($following_dl_colwidths)//column">
9680
- <xsl:call-template name="setColumnWidth_dl">
9681
- <xsl:with-param name="colwidths" select="$following_dl_colwidths"/>
9682
- <xsl:with-param name="maxlength_dt" select="$maxlength_dt"/>
9683
- </xsl:call-template>
9684
- </xsl:when>
9685
- <xsl:otherwise>
9686
- <fo:table-column column-width="5%"/>
9687
- <fo:table-column column-width="95%"/>
9688
- </xsl:otherwise>
9689
- </xsl:choose>
9690
- <fo:table-body>
9691
- <xsl:for-each select="xalan:nodeset($references)//fn">
9692
- <xsl:variable name="reference" select="@reference"/>
9693
- <xsl:if test="not(preceding-sibling::*[@reference = $reference])"> <!-- only unique reference puts in note-->
9694
- <fo:table-row>
9695
- <fo:table-cell>
9696
- <fo:block>
9697
- <fo:inline id="{@id}" xsl:use-attribute-sets="figure-fn-number-style">
9698
- <xsl:value-of select="@reference"/>
9819
+ <xsl:variable name="reference" select="@reference"/>
9820
+ <!-- <xsl:if test="not(preceding-sibling::*[@reference = $reference])"> --> <!-- only unique reference puts in note-->
9821
+ <fo:table-row>
9822
+ <fo:table-cell>
9823
+ <fo:block>
9824
+
9825
+ <fo:inline id="{@id}" xsl:use-attribute-sets="figure-fmt-fn-label-style">
9826
+ <!-- <xsl:attribute name="padding-right">0mm</xsl:attribute> -->
9827
+ <!-- <xsl:value-of select="@reference"/> -->
9828
+ <xsl:value-of select="normalize-space(.//*[local-name() = 'fmt-fn-label'])"/>
9699
9829
  </fo:inline>
9700
- </fo:block>
9701
- </fo:table-cell>
9702
- <fo:table-cell>
9703
- <fo:block xsl:use-attribute-sets="figure-fn-body-style">
9704
- <xsl:if test="normalize-space($key_iso) = 'true'">
9705
9830
 
9706
- <xsl:attribute name="margin-bottom">0</xsl:attribute>
9831
+ </fo:block>
9832
+ </fo:table-cell>
9833
+ <fo:table-cell>
9834
+ <fo:block xsl:use-attribute-sets="figure-fn-body-style">
9835
+ <xsl:if test="normalize-space($key_iso) = 'true'">
9707
9836
 
9708
- </xsl:if>
9709
- <xsl:copy-of select="./node()"/>
9710
- </fo:block>
9711
- </fo:table-cell>
9712
- </fo:table-row>
9713
- </xsl:if>
9714
- </xsl:for-each>
9715
- </fo:table-body>
9716
- </fo:table>
9837
+ <xsl:attribute name="margin-bottom">0</xsl:attribute>
9717
9838
 
9839
+ </xsl:if>
9840
+
9841
+ <!-- <xsl:copy-of select="./node()"/> -->
9842
+ <xsl:apply-templates/>
9843
+ </fo:block>
9844
+ </fo:table-cell>
9845
+ </fo:table-row>
9846
+ <!-- </xsl:if> -->
9847
+ </xsl:for-each>
9848
+ </fo:table-body>
9849
+ </fo:table>
9718
9850
  </fo:block>
9719
9851
  </xsl:if>
9720
- </xsl:template> <!-- fn_display_figure -->
9852
+ </xsl:template> <!-- figure_fn_display -->
9853
+
9854
+ <xsl:template match="*[local-name() = 'figure']//*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']"> <!-- *[local-name() = 'fmt-footnote-container']/ -->
9855
+ <xsl:param name="process">false</xsl:param>
9856
+ <xsl:if test="$process = 'true'">
9857
+ <fo:inline xsl:use-attribute-sets="figure-fn-number-style" role="SKIP">
9858
+ <xsl:attribute name="padding-right">0mm</xsl:attribute>
9859
+
9860
+ <!-- tab is padding-right -->
9861
+ <xsl:apply-templates select=".//*[local-name() = 'tab']">
9862
+ <xsl:with-param name="process">true</xsl:with-param>
9863
+ </xsl:apply-templates>
9864
+
9865
+ <xsl:apply-templates/>
9866
+
9867
+ </fo:inline>
9868
+ </xsl:if>
9869
+ </xsl:template> <!-- figure//fmt-fn-body//fmt-fn-label -->
9870
+
9871
+ <xsl:template match="*[local-name() = 'figure']//*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']//*[local-name() = 'tab']" priority="5">
9872
+ <xsl:param name="process">false</xsl:param>
9873
+ <xsl:if test="$process = 'true'">
9874
+
9875
+ </xsl:if>
9876
+ </xsl:template>
9877
+
9878
+ <xsl:template match="*[local-name() = 'figure']//*[local-name() = 'fmt-fn-body']//*[local-name() = 'fmt-fn-label']//*[local-name() = 'sup']" priority="5">
9879
+ <fo:inline xsl:use-attribute-sets="figure-fmt-fn-label-style" role="SKIP">
9880
+ <xsl:call-template name="refine_figure-fmt-fn-label-style"/>
9881
+ <xsl:apply-templates/>
9882
+ </fo:inline>
9883
+ </xsl:template>
9721
9884
 
9722
9885
  <!-- added for https://github.com/metanorma/isodoc/issues/607 -->
9723
9886
  <!-- figure's footnote label -->
9887
+ <!-- figure/dl[@key = 'true']/dt/p/sup -->
9724
9888
  <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'dl'][@key = 'true']/*[local-name() = 'dt']/ *[local-name() = 'p'][count(node()[normalize-space() != '']) = 1]/*[local-name() = 'sup']" priority="3">
9725
9889
  <xsl:variable name="key_iso">
9726
9890
  true
@@ -9729,7 +9893,7 @@
9729
9893
  <xsl:attribute name="font-size">10pt</xsl:attribute>
9730
9894
 
9731
9895
  </xsl:if>
9732
- <fo:inline xsl:use-attribute-sets="figure-fn-number-style"> <!-- id="{@id}" -->
9896
+ <fo:inline xsl:use-attribute-sets="figure-fn-number-style figure-fmt-fn-label-style"> <!-- id="{@id}" -->
9733
9897
  <!-- <xsl:value-of select="@reference"/> -->
9734
9898
  <xsl:apply-templates/>
9735
9899
  </fo:inline>
@@ -9739,38 +9903,65 @@
9739
9903
  <!-- END: figure's footnotes rendering -->
9740
9904
  <!-- ============================ -->
9741
9905
 
9742
- <!-- fn reference in the text rendering (for instance, 'some text 1) some text' ) -->
9906
+ <!-- fn reference in the table rendering (for instance, 'some text 1) some text' ) -->
9907
+ <!-- fn --> <!-- in table --> <!-- for figure see <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'fn']" priority="2"/> -->
9743
9908
  <xsl:template match="*[local-name()='fn']">
9744
9909
  <fo:inline xsl:use-attribute-sets="fn-reference-style">
9745
9910
 
9746
9911
  <xsl:call-template name="refine_fn-reference-style"/>
9747
9912
 
9748
- <fo:basic-link internal-destination="{@reference}_{ancestor::*[@id][1]/@id}" fox:alt-text="footnote {@reference}"> <!-- @reference | ancestor::*[local-name()='clause'][1]/@id-->
9749
- <xsl:if test="ancestor::*[local-name()='table'][1]/@id"> <!-- for footnotes in tables -->
9750
- <xsl:attribute name="internal-destination">
9913
+ <!-- <fo:basic-link internal-destination="{@reference}_{ancestor::*[@id][1]/@id}" fox:alt-text="footnote {@reference}"> --> <!-- @reference | ancestor::*[local-name()='clause'][1]/@id-->
9914
+ <fo:basic-link internal-destination="{@target}" fox:alt-text="footnote {@reference}">
9915
+ <!-- <xsl:if test="ancestor::*[local-name()='table'][1]/@id"> --> <!-- for footnotes in tables -->
9916
+ <!-- <xsl:attribute name="internal-destination">
9751
9917
  <xsl:value-of select="concat(@reference, '_', ancestor::*[local-name()='table'][1]/@id)"/>
9752
9918
  </xsl:attribute>
9753
9919
  </xsl:if>
9920
+ <xsl:if test="$namespace = 'ogc' or $namespace = 'ogc-white-paper'">
9921
+ <xsl:attribute name="internal-destination">
9922
+ <xsl:value-of select="@reference"/><xsl:text>_</xsl:text>
9923
+ <xsl:value-of select="ancestor::*[local-name()='table'][1]/@id"/>
9924
+ </xsl:attribute>
9925
+ </xsl:if> -->
9926
+ <!-- <xsl:if test="$namespace = 'plateau'">
9927
+ <xsl:text>※</xsl:text>
9928
+ </xsl:if> -->
9929
+ <!-- <xsl:value-of select="@reference"/> -->
9754
9930
 
9755
- <xsl:value-of select="@reference"/>
9931
+ <xsl:value-of select="normalize-space(*[local-name() = 'fmt-fn-label'])"/>
9756
9932
 
9933
+ <!-- <xsl:if test="$namespace = 'bsi'">
9934
+ <xsl:text>)</xsl:text>
9935
+ </xsl:if> -->
9757
9936
  <!-- commented, https://github.com/metanorma/isodoc/issues/614 -->
9758
9937
  <!-- <xsl:if test="$namespace = 'jis'">
9759
9938
  <fo:inline font-weight="normal">)</fo:inline>
9760
9939
  </xsl:if> -->
9761
9940
  </fo:basic-link>
9762
9941
  </fo:inline>
9763
- </xsl:template>
9942
+ </xsl:template> <!-- fn -->
9764
9943
 
9944
+ <!-- fn/text() -->
9765
9945
  <xsl:template match="*[local-name()='fn']/text()[normalize-space() != '']">
9766
9946
  <fo:inline role="SKIP"><xsl:value-of select="."/></fo:inline>
9767
9947
  </xsl:template>
9768
9948
 
9769
- <xsl:template match="*[local-name()='fn']//*[local-name()='p']">
9949
+ <!-- fn//p fmt-fn-body//p -->
9950
+ <xsl:template match="*[local-name()='fn']//*[local-name()='p'] | *[local-name() = 'fmt-fn-body']//*[local-name()='p']">
9770
9951
  <fo:inline role="P">
9771
9952
  <xsl:apply-templates/>
9772
9953
  </fo:inline>
9773
9954
  </xsl:template>
9955
+
9956
+ <xsl:template name="insertFootnoteSeparatorCommon">
9957
+ <xsl:param name="leader_length">30%</xsl:param>
9958
+ <fo:static-content flow-name="xsl-footnote-separator">
9959
+ <fo:block>
9960
+ <fo:leader leader-pattern="rule" leader-length="{$leader_length}"/>
9961
+ </fo:block>
9962
+ </fo:static-content>
9963
+ </xsl:template>
9964
+
9774
9965
  <!-- ===================== -->
9775
9966
  <!-- END Footnotes processing -->
9776
9967
  <!-- ===================== -->
@@ -10055,11 +10246,11 @@
10055
10246
  <xsl:variable name="isContainsKeepTogetherTag" select="normalize-space($isContainsKeepTogetherTag_)"/>
10056
10247
  <!-- isContainsExpressReference=<xsl:value-of select="$isContainsExpressReference"/> -->
10057
10248
 
10058
- <xsl:call-template name="setColumnWidth_dl">
10059
- <xsl:with-param name="colwidths" select="$colwidths"/>
10060
- <xsl:with-param name="maxlength_dt" select="$maxlength_dt"/>
10061
- <xsl:with-param name="isContainsKeepTogetherTag" select="$isContainsKeepTogetherTag"/>
10062
- </xsl:call-template>
10249
+ <xsl:call-template name="setColumnWidth_dl">
10250
+ <xsl:with-param name="colwidths" select="$colwidths"/>
10251
+ <xsl:with-param name="maxlength_dt" select="$maxlength_dt"/>
10252
+ <xsl:with-param name="isContainsKeepTogetherTag" select="$isContainsKeepTogetherTag"/>
10253
+ </xsl:call-template>
10063
10254
 
10064
10255
  <fo:table-body>
10065
10256
 
@@ -10093,6 +10284,14 @@
10093
10284
 
10094
10285
  </xsl:template> <!-- END: dl -->
10095
10286
 
10287
+ <xsl:template match="@*|node()" mode="dt_clean">
10288
+ <xsl:copy>
10289
+ <xsl:apply-templates select="@*|node()" mode="dt_clean"/>
10290
+ </xsl:copy>
10291
+ </xsl:template>
10292
+
10293
+ <xsl:template match="*[local-name() = 'asciimath']" mode="dt_clean"/>
10294
+
10096
10295
  <!-- caption for figure key and another caption, https://github.com/metanorma/isodoc/issues/607 -->
10097
10296
  <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'p'][@keep-with-next = 'true' and *[local-name() = 'strong']]" priority="3">
10098
10297
  <fo:block text-align="left" margin-bottom="12pt" keep-with-next="always">
@@ -10132,10 +10331,12 @@
10132
10331
  <!-- ignore 'p' with 'where' in formula, before 'dl' -->
10133
10332
  <xsl:template match="*[local-name() = 'formula']/*[local-name() = 'p' and @keep-with-next = 'true' and following-sibling::*[1][local-name() = 'dl']]"/>
10134
10333
 
10334
+ <!-- dl/name -->
10135
10335
  <xsl:template match="*[local-name() = 'dl']/*[local-name() = 'name']">
10136
10336
  <xsl:param name="process">false</xsl:param>
10137
10337
  <xsl:if test="$process = 'true'">
10138
10338
  <fo:block xsl:use-attribute-sets="dl-name-style">
10339
+
10139
10340
  <xsl:apply-templates/>
10140
10341
  </fo:block>
10141
10342
  </xsl:if>
@@ -10149,6 +10350,10 @@
10149
10350
  <!-- <colwidths><xsl:copy-of select="$colwidths"/></colwidths> -->
10150
10351
 
10151
10352
  <xsl:choose>
10353
+ <!-- <xsl:when test="@class = 'formula_dl' and local-name(..) = 'figure'">
10354
+ <fo:table-column column-width="10%"/>
10355
+ <fo:table-column column-width="90%"/>
10356
+ </xsl:when> -->
10152
10357
  <xsl:when test="xalan:nodeset($colwidths)/autolayout">
10153
10358
  <xsl:call-template name="insertTableColumnWidth">
10154
10359
  <xsl:with-param name="colwidths" select="$colwidths"/>
@@ -11027,7 +11232,7 @@
11027
11232
  <xsl:choose>
11028
11233
  <xsl:when test="ancestor::*[local-name() = 'table']"><xsl:apply-templates/></xsl:when>
11029
11234
  <xsl:when test="following-sibling::*[2][local-name() = 'span'][@class = 'stdpublisher' or @class = 'stddocNumber' or @class = 'stddocPartNumber' or @class = 'stdyear']">
11030
- <fo:inline keep-with-next.within-line="always"><xsl:apply-templates/></fo:inline>
11235
+ <fo:inline keep-with-next.within-line="always" role="SKIP"><xsl:apply-templates/></fo:inline>
11031
11236
  </xsl:when>
11032
11237
  <xsl:otherwise>
11033
11238
  <xsl:apply-templates/>
@@ -11035,7 +11240,7 @@
11035
11240
  </xsl:choose>
11036
11241
  </xsl:template>
11037
11242
  <xsl:template match="text()[not(ancestor::*[local-name() = 'table']) and preceding-sibling::*[1][local-name() = 'span'][@class = 'stdpublisher' or @class = 'stddocNumber' or @class = 'stddocPartNumber' or @class = 'stdyear'] and following-sibling::*[1][local-name() = 'span'][@class = 'stdpublisher' or @class = 'stddocNumber' or @class = 'stddocPartNumber' or @class = 'stdyear']]" priority="2">
11038
- <fo:inline keep-with-next.within-line="always"><xsl:value-of select="."/></fo:inline>
11243
+ <fo:inline keep-with-next.within-line="always" role="SKIP"><xsl:value-of select="."/></fo:inline>
11039
11244
  </xsl:template>
11040
11245
 
11041
11246
  <xsl:template match="*[local-name() = 'span'][contains(@style, 'text-transform:none')]//text()" priority="5">
@@ -12075,24 +12280,26 @@
12075
12280
  <xsl:apply-templates select="." mode="mathml"/>
12076
12281
  </xsl:variable>
12077
12282
 
12078
- <fo:instream-foreign-object fox:alt-text="Math">
12283
+ <fo:instream-foreign-object fox:alt-text="Math" fox:actual-text="Math">
12079
12284
 
12080
12285
  <xsl:call-template name="refine_mathml_insteam_object_style"/>
12081
12286
 
12082
- <!-- put MathML in Actual Text -->
12083
- <!-- DEBUG: mathml_content=<xsl:value-of select="$mathml_content"/> -->
12084
- <xsl:attribute name="fox:actual-text">
12085
- <xsl:value-of select="$mathml_content"/>
12086
- </xsl:attribute>
12087
-
12088
- <!-- <xsl:if test="$add_math_as_text = 'true'"> -->
12089
- <xsl:if test="normalize-space($asciimath_text_) != ''">
12090
- <!-- put Mathin Alternate Text -->
12091
- <xsl:attribute name="fox:alt-text">
12092
- <xsl:value-of select="$asciimath_text_"/>
12287
+ <xsl:if test="$isGenerateTableIF = 'false'">
12288
+ <!-- put MathML in Actual Text -->
12289
+ <!-- DEBUG: mathml_content=<xsl:value-of select="$mathml_content"/> -->
12290
+ <xsl:attribute name="fox:actual-text">
12291
+ <xsl:value-of select="$mathml_content"/>
12093
12292
  </xsl:attribute>
12293
+
12294
+ <!-- <xsl:if test="$add_math_as_text = 'true'"> -->
12295
+ <xsl:if test="normalize-space($asciimath_text_) != ''">
12296
+ <!-- put Mathin Alternate Text -->
12297
+ <xsl:attribute name="fox:alt-text">
12298
+ <xsl:value-of select="$asciimath_text_"/>
12299
+ </xsl:attribute>
12300
+ </xsl:if>
12301
+ <!-- </xsl:if> -->
12094
12302
  </xsl:if>
12095
- <!-- </xsl:if> -->
12096
12303
 
12097
12304
  <xsl:copy-of select="xalan:nodeset($mathml)"/>
12098
12305
 
@@ -12362,6 +12569,27 @@
12362
12569
  <xsl:variable name="target__" select="substring-after($target_, concat('_', $inputxml_filename_prefix, '_attachments', '/'))"/>
12363
12570
  <xsl:value-of select="concat('url(embedded-file:', $target__, ')')"/>
12364
12571
  </xsl:when> -->
12572
+
12573
+ <!-- <xsl:when test="not(starts-with(@target, 'http:') or starts-with(@target, 'https') or starts-with(@target, 'www') or starts-with(@target, 'mailto') or starts-with(@target, 'ftp'))">
12574
+ <xsl:variable name="target_" select="translate(@target, '\', '/')"/>
12575
+ <xsl:variable name="filename">
12576
+ <xsl:call-template name="substring-after-last">
12577
+ <xsl:with-param name="value" select="$target_"/>
12578
+ <xsl:with-param name="delimiter" select="'/'"/>
12579
+ </xsl:call-template>
12580
+ </xsl:variable>
12581
+ <xsl:variable name="target_filepath" select="concat($inputxml_basepath, @target)"/>
12582
+ <xsl:variable name="file_exists" select="normalize-space(java:exists(java:java.io.File.new($target_filepath)))"/>
12583
+ <xsl:choose>
12584
+ <xsl:when test="$file_exists = 'true'">
12585
+ <xsl:value-of select="concat('url(embedded-file:', $filename, ')')"/>
12586
+ </xsl:when>
12587
+ <xsl:otherwise>
12588
+ <xsl:value-of select="normalize-space(@target)"/>
12589
+ </xsl:otherwise>
12590
+ </xsl:choose>
12591
+ </xsl:when> -->
12592
+
12365
12593
  <xsl:otherwise>
12366
12594
  <xsl:value-of select="normalize-space(@target)"/>
12367
12595
  </xsl:otherwise>
@@ -12691,7 +12919,7 @@
12691
12919
  </xsl:if>
12692
12920
  </xsl:if>
12693
12921
 
12694
- </xsl:template>
12922
+ </xsl:template> <!-- refine_note_block_style -->
12695
12923
 
12696
12924
  <xsl:template match="*[local-name() = 'note']/*[local-name() = 'p']">
12697
12925
  <xsl:variable name="num"><xsl:number/></xsl:variable>
@@ -12889,10 +13117,21 @@
12889
13117
  </xsl:template>
12890
13118
 
12891
13119
  <xsl:template name="showFigureKey">
12892
- <xsl:for-each select="*[local-name() = 'note'][not(@type = 'units')]">
12893
- <xsl:call-template name="note"/>
13120
+ <xsl:for-each select="*[(local-name() = 'note' and not(@type = 'units')) or local-name() = 'example']">
13121
+ <xsl:choose>
13122
+ <xsl:when test="local-name() = 'note'">
13123
+ <xsl:call-template name="note"/>
13124
+ </xsl:when>
13125
+ <xsl:when test="local-name() = 'example'">
13126
+ <xsl:call-template name="example"/>
13127
+ </xsl:when>
13128
+ <xsl:otherwise>
13129
+ <xsl:apply-templates select="."/>
13130
+ </xsl:otherwise>
13131
+ </xsl:choose>
12894
13132
  </xsl:for-each>
12895
- <xsl:call-template name="fn_display_figure"/>
13133
+ <!-- TO DO: remove, now the figure fn in figure/dl/... https://github.com/metanorma/isodoc/issues/658 -->
13134
+ <xsl:call-template name="figure_fn_display"/>
12896
13135
  </xsl:template>
12897
13136
 
12898
13137
  <xsl:template match="*[local-name() = 'figure'][@class = 'pseudocode']">
@@ -13786,10 +14025,10 @@
13786
14025
  <xsl:when test="@type = 'section-title'">
13787
14026
  <xsl:value-of select="*[local-name() = 'span'][@class = 'fmt-caption-delim'][1]/preceding-sibling::node()"/>
13788
14027
  <xsl:text>: </xsl:text>
13789
- <xsl:copy-of select="*[local-name() = 'span'][@class = 'fmt-caption-delim'][1]/following-sibling::node()[not(local-name = 'fmt-xref-label')]"/>
14028
+ <xsl:copy-of select="*[local-name() = 'span'][@class = 'fmt-caption-delim'][1]/following-sibling::node()[not(local-name() = 'fmt-xref-label')]"/>
13790
14029
  </xsl:when>
13791
14030
  <xsl:otherwise>
13792
- <xsl:copy-of select="*[local-name() = 'span'][@class = 'fmt-caption-delim'][1]/following-sibling::node()[not(local-name = 'fmt-xref-label')]"/>
14031
+ <xsl:copy-of select="*[local-name() = 'span'][@class = 'fmt-caption-delim'][1]/following-sibling::node()[not(local-name() = 'fmt-xref-label')]"/>
13793
14032
  </xsl:otherwise>
13794
14033
  </xsl:choose>
13795
14034
  </xsl:when>
@@ -13854,6 +14093,8 @@
13854
14093
  <xsl:template match="*[local-name() = 'origin']" mode="contents"/>
13855
14094
  <xsl:template match="*[local-name() = 'erefstack ']" mode="contents"/>
13856
14095
 
14096
+ <xsl:template match="*[local-name() = 'requirement'] | *[local-name() = 'recommendation'] | *[local-name() = 'permission']" mode="contents" priority="3"/>
14097
+
13857
14098
  <xsl:template match="*[local-name() = 'stem']" mode="bookmarks"/>
13858
14099
  <xsl:template match="*[local-name() = 'fmt-stem']" mode="bookmarks">
13859
14100
  <xsl:apply-templates mode="bookmarks"/>
@@ -13875,6 +14116,8 @@
13875
14116
  <xsl:template match="*[local-name() = 'origin']" mode="bookmarks"/>
13876
14117
  <xsl:template match="*[local-name() = 'erefstack ']" mode="bookmarks"/>
13877
14118
 
14119
+ <xsl:template match="*[local-name() = 'requirement'] | *[local-name() = 'recommendation'] | *[local-name() = 'permission']" mode="bookmarks" priority="3"/>
14120
+
13878
14121
  <!-- Bookmarks -->
13879
14122
  <xsl:template name="addBookmarks">
13880
14123
  <xsl:param name="contents"/>
@@ -14120,9 +14363,15 @@
14120
14363
  </xsl:if>
14121
14364
  </xsl:template>
14122
14365
 
14366
+ <!-- figure/fn -->
14123
14367
  <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'fn']" priority="2"/>
14124
- <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'note']"/>
14368
+ <!-- figure/note -->
14369
+ <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'note']" priority="2"/>
14370
+ <!-- figure/example -->
14371
+ <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'example']" priority="2"/>
14125
14372
 
14373
+ <!-- figure/note[@type = 'units'] -->
14374
+ <!-- image/note[@type = 'units'] -->
14126
14375
  <xsl:template match="*[local-name() = 'figure']/*[local-name() = 'note'][@type = 'units'] | *[local-name() = 'image']/*[local-name() = 'note'][@type = 'units']" priority="2">
14127
14376
  <fo:block text-align="right" keep-with-next="always">
14128
14377
  <xsl:apply-templates/>
@@ -14243,6 +14492,7 @@
14243
14492
  </xsl:choose>
14244
14493
  </xsl:template>
14245
14494
 
14495
+ <!-- fn -->
14246
14496
  <xsl:template match="*[local-name() = 'fn']" mode="contents"/>
14247
14497
  <xsl:template match="*[local-name() = 'fn']" mode="bookmarks"/>
14248
14498
 
@@ -15140,7 +15390,7 @@
15140
15390
  text line 1
15141
15391
  text line 2
15142
15392
  -->
15143
- <xsl:template match="*[local-name() = 'example']">
15393
+ <xsl:template match="*[local-name() = 'example']" name="example">
15144
15394
 
15145
15395
  <fo:block-container id="{@id}" xsl:use-attribute-sets="example-style" role="SKIP">
15146
15396
 
@@ -15251,6 +15501,7 @@
15251
15501
 
15252
15502
  </xsl:template>
15253
15503
 
15504
+ <!-- example/name -->
15254
15505
  <xsl:template match="*[local-name() = 'example']/*[local-name() = 'name']">
15255
15506
  <xsl:param name="fo_element">block</xsl:param>
15256
15507
 
@@ -15276,7 +15527,8 @@
15276
15527
 
15277
15528
  </xsl:template>
15278
15529
 
15279
- <xsl:template match="*[local-name() = 'table']/*[local-name() = 'example']/*[local-name() = 'name']">
15530
+ <!-- table/example/name, table/tfoot//example/name -->
15531
+ <xsl:template match="*[local-name() = 'table']/*[local-name() = 'example']/*[local-name() = 'name'] | *[local-name() = 'table']/*[local-name() = 'tfoot']//*[local-name() = 'example']/*[local-name() = 'name']">
15280
15532
  <fo:inline xsl:use-attribute-sets="example-name-style">
15281
15533
 
15282
15534
  <xsl:apply-templates/>
@@ -15759,21 +16011,32 @@
15759
16011
  <!-- ========== -->
15760
16012
 
15761
16013
  <xsl:variable name="reviews_">
15762
- <xsl:for-each select="//*[local-name() = 'review'][@from]">
16014
+ <xsl:for-each select="//*[local-name() = 'review'][not(parent::*[local-name() = 'review-container'])][@from]">
15763
16015
  <xsl:copy>
15764
16016
  <xsl:copy-of select="@from"/>
15765
16017
  <xsl:copy-of select="@id"/>
15766
16018
  </xsl:copy>
15767
16019
  </xsl:for-each>
16020
+ <xsl:for-each select="//*[local-name() = 'fmt-review-start'][@source]">
16021
+ <xsl:copy>
16022
+ <xsl:copy-of select="@source"/>
16023
+ <xsl:copy-of select="@id"/>
16024
+ </xsl:copy>
16025
+ </xsl:for-each>
15768
16026
  </xsl:variable>
15769
16027
  <xsl:variable name="reviews" select="xalan:nodeset($reviews_)"/>
15770
16028
 
15771
16029
  <xsl:template name="addReviewHelper">
15772
- <!-- if there is review with from="...", then add small helper block for Annot tag adding, see 'review' template -->
15773
- <xsl:variable name="curr_id" select="@id"/>
15774
- <xsl:variable name="review_id" select="normalize-space($reviews//*[local-name() = 'review'][@from = $curr_id]/@id)"/>
15775
- <xsl:if test="$review_id != ''"> <!-- i.e. if review found -->
15776
- <fo:block keep-with-next="always" line-height="0.1" id="{$review_id}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{$review_id}" fox:alt-text="Annot___{$review_id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16030
+ <xsl:if test="$isGenerateTableIF = 'false'">
16031
+ <!-- if there is review with from="...", then add small helper block for Annot tag adding, see 'review' template -->
16032
+ <xsl:variable name="curr_id" select="@id"/>
16033
+ <!-- <xsl:variable name="review_id" select="normalize-space(/@id)"/> -->
16034
+ <xsl:for-each select="$reviews//*[local-name() = 'review'][@from = $curr_id]"> <!-- $reviews//*[local-name() = 'fmt-review-start'][@source = $curr_id] -->
16035
+ <xsl:variable name="review_id" select="normalize-space(@id)"/>
16036
+ <xsl:if test="$review_id != ''"> <!-- i.e. if review found -->
16037
+ <fo:block keep-with-next="always" line-height="0.1" id="{$review_id}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{$review_id}" fox:alt-text="Annot___{$review_id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16038
+ </xsl:if>
16039
+ </xsl:for-each>
15777
16040
  </xsl:if>
15778
16041
  <!-- <fo:block>
15779
16042
  <curr_id><xsl:value-of select="$curr_id"/></curr_id>
@@ -15921,14 +16184,61 @@
15921
16184
 
15922
16185
  </xsl:template>
15923
16186
 
15924
- <xsl:template match="*[local-name() = 'review']"> <!-- 'review' will be processed in mn2pdf/review.xsl -->
16187
+ <!-- document text (not figures, or tables) footnotes -->
16188
+ <xsl:variable name="reviews_container_">
16189
+ <xsl:for-each select="//*[local-name() = 'review-container']/*[local-name() = 'fmt-review-body']">
16190
+ <xsl:variable name="update_xml_step1">
16191
+ <xsl:apply-templates select="." mode="update_xml_step1"/>
16192
+ </xsl:variable>
16193
+ <xsl:apply-templates select="xalan:nodeset($update_xml_step1)" mode="update_xml_enclose_keep-together_within-line"/>
16194
+ </xsl:for-each>
16195
+ </xsl:variable>
16196
+ <xsl:variable name="reviews_container" select="xalan:nodeset($reviews_container_)"/>
16197
+
16198
+ <xsl:template match="*[local-name() = 'review-container']"/>
16199
+
16200
+ <!-- for old Presentation XML (before https://github.com/metanorma/isodoc/issues/670) -->
16201
+ <xsl:template match="*[local-name() = 'review'][not(parent::*[local-name() = 'review-container'])]"> <!-- 'review' will be processed in mn2pdf/review.xsl -->
16202
+ <xsl:variable name="id_from" select="normalize-space(current()/@from)"/>
16203
+ <xsl:if test="$isGenerateTableIF = 'false'">
16204
+ <xsl:choose>
16205
+ <!-- if there isn't the attribute '@from', then -->
16206
+ <xsl:when test="$id_from = ''">
16207
+ <fo:block id="{@id}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{@id}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16208
+ </xsl:when>
16209
+ <!-- if there isn't element with id 'from', then create 'bookmark' here -->
16210
+ <xsl:when test="ancestor::*[local-name() = 'metanorma'] and not(ancestor::*[local-name() = 'metanorma']//*[@id = $id_from])">
16211
+ <fo:block id="{@from}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{@from}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16212
+ </xsl:when>
16213
+ <xsl:when test="not(/*[@id = $id_from]) and not(/*//*[@id = $id_from]) and not(preceding-sibling::*[@id = $id_from])">
16214
+ <fo:block id="{@from}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{@from}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16215
+ </xsl:when>
16216
+ </xsl:choose>
16217
+ </xsl:if>
16218
+ </xsl:template>
16219
+
16220
+ <!-- for new Presentation XML (https://github.com/metanorma/isodoc/issues/670) -->
16221
+ <xsl:template match="*[local-name() = 'fmt-review-start']" name="fmt-review-start"> <!-- 'review' will be processed in mn2pdf/review.xsl -->
15925
16222
  <!-- comment 2019-11-29 -->
15926
16223
  <!-- <fo:block font-weight="bold">Review:</fo:block>
15927
16224
  <xsl:apply-templates /> -->
15928
16225
 
15929
- <xsl:variable name="id_from" select="normalize-space(current()/@from)"/>
16226
+ <xsl:variable name="id_from" select="normalize-space(current()/@source)"/>
15930
16227
 
15931
- <xsl:if test="1 = 1">
16228
+ <xsl:variable name="source" select="normalize-space(@source)"/>
16229
+
16230
+ <xsl:if test="$isGenerateTableIF = 'false'">
16231
+ <!-- <xsl:variable name="id_from" select="normalize-space(current()/@from)"/> -->
16232
+
16233
+ <!-- <xsl:if test="@source = @end"> -->
16234
+ <!-- following-sibling::node()[1][local-name() = 'bookmark'][@id = $source] and
16235
+ following-sibling::node()[2][local-name() = 'fmt-review-end'][@source = $source] -->
16236
+ <!-- <fo:block id="{$source}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{$source}" fox:alt-text="Annot___{$source}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block> -->
16237
+ <fo:block id="{@id}" font-size="1pt" role="SKIP" keep-with-next="always" line-height="0.1"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{@id}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16238
+ <!-- </xsl:if> -->
16239
+ </xsl:if>
16240
+
16241
+ <xsl:if test="1 = 2">
15932
16242
  <xsl:choose>
15933
16243
  <!-- if there isn't the attribute '@from', then -->
15934
16244
  <xsl:when test="$id_from = ''">
@@ -15936,10 +16246,10 @@
15936
16246
  </xsl:when>
15937
16247
  <!-- if there isn't element with id 'from', then create 'bookmark' here -->
15938
16248
  <xsl:when test="ancestor::*[local-name() = 'metanorma'] and not(ancestor::*[local-name() = 'metanorma']//*[@id = $id_from])">
15939
- <fo:block id="{@from}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{@from}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16249
+ <fo:block id="{$id_from}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{$id_from}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
15940
16250
  </xsl:when>
15941
16251
  <xsl:when test="not(/*[@id = $id_from]) and not(/*//*[@id = $id_from]) and not(preceding-sibling::*[@id = $id_from])">
15942
- <fo:block id="{@from}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{@from}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
16252
+ <fo:block id="{$id_from}" font-size="1pt" role="SKIP"><xsl:value-of select="$hair_space"/><fo:basic-link internal-destination="{$id_from}" fox:alt-text="Annot___{@id}" role="Annot"><xsl:value-of select="$hair_space"/></fo:basic-link></fo:block>
15943
16253
  </xsl:when>
15944
16254
  </xsl:choose>
15945
16255
  </xsl:if>
@@ -15995,16 +16305,21 @@
15995
16305
  <xsl:variable name="list_level">
15996
16306
  <xsl:choose>
15997
16307
  <xsl:when test="$list_level_ &lt;= 3"><xsl:value-of select="$list_level_"/></xsl:when>
15998
- <xsl:otherwise><xsl:value-of select="$list_level_ mod 3"/></xsl:otherwise>
16308
+ <xsl:when test="$ul_labels/label[@level = 3]"><xsl:value-of select="$list_level_ mod 3"/></xsl:when>
16309
+ <xsl:when test="$list_level_ mod 2 = 0">2</xsl:when>
16310
+ <xsl:otherwise><xsl:value-of select="$list_level_ mod 2"/></xsl:otherwise>
15999
16311
  </xsl:choose>
16000
16312
  </xsl:variable>
16001
16313
  <xsl:choose>
16002
16314
  <xsl:when test="$ul_labels/label[not(@level)]"> <!-- one label for all levels -->
16003
16315
  <xsl:apply-templates select="$ul_labels/label[not(@level)]" mode="ul_labels"/>
16004
16316
  </xsl:when>
16005
- <xsl:when test="$list_level mod 3 = 0">
16317
+ <xsl:when test="$list_level mod 3 = 0 and $ul_labels/label[@level = 3]">
16006
16318
  <xsl:apply-templates select="$ul_labels/label[@level = 3]" mode="ul_labels"/>
16007
16319
  </xsl:when>
16320
+ <xsl:when test="$list_level mod 3 = 0">
16321
+ <xsl:apply-templates select="$ul_labels/label[@level = 1]" mode="ul_labels"/>
16322
+ </xsl:when>
16008
16323
  <xsl:when test="$list_level mod 2 = 0">
16009
16324
  <xsl:apply-templates select="$ul_labels/label[@level = 2]" mode="ul_labels"/>
16010
16325
  </xsl:when>
@@ -16584,10 +16899,22 @@
16584
16899
  <xsl:template match="*[local-name() = 'table']/*[local-name() = 'bookmark']" priority="2"/>
16585
16900
 
16586
16901
  <xsl:template match="*[local-name() = 'bookmark']" name="bookmark">
16587
- <!-- <fo:inline id="{@id}" font-size="1pt"/> -->
16588
- <fo:inline id="{@id}" font-size="1pt"><xsl:value-of select="$hair_space"/></fo:inline>
16589
- <!-- we need to add zero-width space, otherwise this fo:inline is missing in IF xml -->
16590
- <xsl:if test="not(following-sibling::node()[normalize-space() != ''])"><fo:inline font-size="1pt"> </fo:inline></xsl:if>
16902
+ <xsl:variable name="bookmark_id" select="@id"/>
16903
+ <xsl:choose>
16904
+ <!-- Example:
16905
+ <fmt-review-start id="_7ef81cf7-3f6c-4ed4-9c1f-1ba092052bbd" source="_dda23915-8574-ef1e-29a1-822d465a5b97" target="_ecfb2210-3b1b-46a2-b63a-8b8505be6686" end="_dda23915-8574-ef1e-29a1-822d465a5b97" author="" date="2025-03-24T00:00:00Z"/>
16906
+ <bookmark id="_dda23915-8574-ef1e-29a1-822d465a5b97"/>
16907
+ <fmt-review-end id="_f336a8d0-08a8-4b7f-a1aa-b04688ed40c1" source="_dda23915-8574-ef1e-29a1-822d465a5b97" target="_ecfb2210-3b1b-46a2-b63a-8b8505be6686" start="_dda23915-8574-ef1e-29a1-822d465a5b97" author="" date="2025-03-24T00:00:00Z"/> -->
16908
+ <xsl:when test="1 = 2 and preceding-sibling::node()[local-name() = 'fmt-review-start'][@source = $bookmark_id] and following-sibling::node()[local-name() = 'fmt-review-end'][@source = $bookmark_id]">
16909
+ <!-- skip here, see the template 'fmt-review-start' -->
16910
+ </xsl:when>
16911
+ <xsl:otherwise>
16912
+ <!-- <fo:inline id="{@id}" font-size="1pt"/> -->
16913
+ <fo:inline id="{@id}" font-size="1pt"><xsl:if test="preceding-sibling::node()[local-name() = 'fmt-review-start'][@source = $bookmark_id] and following-sibling::node()[local-name() = 'fmt-review-end'][@source = $bookmark_id]"><xsl:attribute name="line-height">0.1</xsl:attribute></xsl:if><xsl:value-of select="$hair_space"/></fo:inline>
16914
+ <!-- we need to add zero-width space, otherwise this fo:inline is missing in IF xml -->
16915
+ <xsl:if test="not(following-sibling::node()[normalize-space() != ''])"><fo:inline font-size="1pt"> </fo:inline></xsl:if>
16916
+ </xsl:otherwise>
16917
+ </xsl:choose>
16591
16918
  </xsl:template>
16592
16919
  <!-- =================== -->
16593
16920
  <!-- End of Index processing -->
@@ -16977,8 +17304,33 @@
16977
17304
 
16978
17305
  <xsl:template match="*[local-name() = 'toc']//*[local-name() = 'xref']" priority="3">
16979
17306
  <!-- <xref target="cgpm9th1948r6">1.6.3<tab/>&#8220;9th CGPM, 1948:<tab/>decision to establish the SI&#8221;</xref> -->
17307
+ <!-- New format: one tab <xref target="cgpm9th1948r6">&#8220;9th CGPM, 1948:<tab/>decision to establish the SI&#8221;</xref> -->
17308
+ <!-- <test><xsl:copy-of select="."/></test> -->
17309
+
16980
17310
  <xsl:variable name="target" select="@target"/>
17311
+
16981
17312
  <xsl:for-each select="*[local-name() = 'tab']">
17313
+
17314
+ <xsl:if test="position() = 1">
17315
+ <!-- first column (data before first `tab`) -->
17316
+ <fo:table-cell>
17317
+ <fo:block line-height-shift-adjustment="disregard-shifts" role="SKIP">
17318
+ <xsl:call-template name="insert_basic_link">
17319
+ <xsl:with-param name="element">
17320
+ <fo:basic-link internal-destination="{$target}" fox:alt-text="{.}">
17321
+ <xsl:for-each select="preceding-sibling::node()">
17322
+ <xsl:choose>
17323
+ <xsl:when test="self::text()"><xsl:value-of select="."/></xsl:when>
17324
+ <xsl:otherwise><xsl:apply-templates select="."/></xsl:otherwise>
17325
+ </xsl:choose>
17326
+ </xsl:for-each>
17327
+ </fo:basic-link>
17328
+ </xsl:with-param>
17329
+ </xsl:call-template>
17330
+ </fo:block>
17331
+ </fo:table-cell>
17332
+ </xsl:if>
17333
+
16982
17334
  <xsl:variable name="current_id" select="generate-id()"/>
16983
17335
  <fo:table-cell>
16984
17336
  <fo:block line-height-shift-adjustment="disregard-shifts" role="SKIP">
@@ -17029,11 +17381,25 @@
17029
17381
 
17030
17382
  <xsl:template match="*[local-name() = 'xref']" mode="toc_table_width">
17031
17383
  <!-- <xref target="cgpm9th1948r6">1.6.3<tab/>&#8220;9th CGPM, 1948:<tab/>decision to establish the SI&#8221;</xref> -->
17384
+ <!-- New format - one tab <xref target="cgpm9th1948r6">&#8220;9th CGPM, 1948:<tab/>decision to establish the SI&#8221;</xref> -->
17032
17385
  <xsl:for-each select="*[local-name() = 'tab']">
17386
+ <xsl:if test="position() = 1">
17387
+ <td>
17388
+ <xsl:for-each select="preceding-sibling::node()">
17389
+ <xsl:choose>
17390
+ <xsl:when test="self::text()"><xsl:value-of select="."/></xsl:when>
17391
+ <xsl:otherwise><xsl:copy-of select="."/></xsl:otherwise>
17392
+ </xsl:choose>
17393
+ </xsl:for-each>
17394
+ </td>
17395
+ </xsl:if>
17033
17396
  <xsl:variable name="current_id" select="generate-id()"/>
17034
17397
  <td>
17035
17398
  <xsl:for-each select="following-sibling::node()[not(self::*[local-name() = 'tab']) and preceding-sibling::*[local-name() = 'tab'][1][generate-id() = $current_id]]">
17036
- <xsl:copy-of select="."/>
17399
+ <xsl:choose>
17400
+ <xsl:when test="self::text()"><xsl:value-of select="."/></xsl:when>
17401
+ <xsl:otherwise><xsl:copy-of select="."/></xsl:otherwise>
17402
+ </xsl:choose>
17037
17403
  </xsl:for-each>
17038
17404
  </td>
17039
17405
  </xsl:for-each>
@@ -17907,6 +18273,9 @@
17907
18273
  <xsl:template match="*[local-name() = 'svgmap']" mode="update_xml_step1"/>
17908
18274
  <xsl:template match="*[local-name() = 'svgmap']" mode="update_xml_pres"/>
17909
18275
 
18276
+ <xsl:template match="*[local-name() = 'review-container']" mode="update_xml_step1"/>
18277
+ <xsl:template match="*[local-name() = 'review-container']" mode="update_xml_pres"/>
18278
+
17910
18279
  <!-- END: update new Presentation XML -->
17911
18280
 
17912
18281
  <!-- =========================================================================== -->
@@ -18553,6 +18922,7 @@
18553
18922
  <p id="_8e5cf917-f75a-4a49-b0aa-1714cb6cf954">Formerly denoted as 15 % (m/m).</p>
18554
18923
  </fn>
18555
18924
  -->
18925
+ <!-- fn in text -->
18556
18926
  <xsl:template match="*[local-name() = 'fn'][not(ancestor::*[(local-name() = 'table' or local-name() = 'figure')] and not(ancestor::*[local-name() = 'name']))]" mode="linear_xml" name="linear_xml_fn">
18557
18927
  <xsl:variable name="p_fn_">
18558
18928
  <xsl:call-template name="get_fn_list"/>