mkdocs2confluence 0.7.11__tar.gz → 0.7.13__tar.gz

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.
Files changed (72) hide show
  1. {mkdocs2confluence-0.7.11/src/mkdocs2confluence.egg-info → mkdocs2confluence-0.7.13}/PKG-INFO +1 -1
  2. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/pyproject.toml +1 -1
  3. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13/src/mkdocs2confluence.egg-info}/PKG-INFO +1 -1
  4. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/emitter/xhtml.py +15 -19
  5. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/abbrevs.py +13 -1
  6. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_abbrevs.py +20 -0
  7. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_emitter.py +18 -0
  8. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/LICENSE +0 -0
  9. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/README.md +0 -0
  10. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/setup.cfg +0 -0
  11. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs2confluence.egg-info/SOURCES.txt +0 -0
  12. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs2confluence.egg-info/dependency_links.txt +0 -0
  13. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs2confluence.egg-info/entry_points.txt +0 -0
  14. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs2confluence.egg-info/requires.txt +0 -0
  15. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs2confluence.egg-info/top_level.txt +0 -0
  16. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/__init__.py +0 -0
  17. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/cli.py +0 -0
  18. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/emitter/__init__.py +0 -0
  19. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/ir/__init__.py +0 -0
  20. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/ir/document.py +0 -0
  21. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/ir/nodes.py +0 -0
  22. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/ir/treeutil.py +0 -0
  23. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/loader/__init__.py +0 -0
  24. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/loader/config.py +0 -0
  25. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/loader/extra_css.py +0 -0
  26. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/loader/nav.py +0 -0
  27. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/loader/page.py +0 -0
  28. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/parser/__init__.py +0 -0
  29. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/parser/markdown.py +0 -0
  30. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/pdf/__init__.py +0 -0
  31. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/pdf/generator.py +0 -0
  32. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/pdf/render.py +0 -0
  33. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/__init__.py +0 -0
  34. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/abbrevs.py +0 -0
  35. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/fence.py +0 -0
  36. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/frontmatter.py +0 -0
  37. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/icons.py +0 -0
  38. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/includes.py +0 -0
  39. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preprocess/linkdefs.py +0 -0
  40. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preview/__init__.py +0 -0
  41. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preview/render.py +0 -0
  42. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/preview/server.py +0 -0
  43. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/publisher/__init__.py +0 -0
  44. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/publisher/client.py +0 -0
  45. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/publisher/pipeline.py +0 -0
  46. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/__init__.py +0 -0
  47. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/assets.py +0 -0
  48. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/editlink.py +0 -0
  49. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/images.py +0 -0
  50. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/internallinks.py +0 -0
  51. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/src/mkdocs_to_confluence/transforms/mermaid.py +0 -0
  52. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_cli.py +0 -0
  53. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_editlink.py +0 -0
  54. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_extra_css.py +0 -0
  55. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_frontmatter.py +0 -0
  56. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_icons.py +0 -0
  57. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_images.py +0 -0
  58. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_internallinks.py +0 -0
  59. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_ir.py +0 -0
  60. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_linkdefs.py +0 -0
  61. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_loader.py +0 -0
  62. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_mermaid.py +0 -0
  63. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_page_loader.py +0 -0
  64. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_parser.py +0 -0
  65. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_pdf.py +0 -0
  66. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_preprocess.py +0 -0
  67. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_preview.py +0 -0
  68. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_publish_client.py +0 -0
  69. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_publish_config.py +0 -0
  70. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_publish_pipeline.py +0 -0
  71. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_server.py +0 -0
  72. {mkdocs2confluence-0.7.11 → mkdocs2confluence-0.7.13}/tests/test_treeutil.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mkdocs2confluence
3
- Version: 0.7.11
3
+ Version: 0.7.13
4
4
  Summary: Publish MkDocs Material pages to Confluence Cloud — admonitions, Mermaid diagrams, tabs, page properties and more
5
5
  Author: Anders Hybertz
6
6
  License: GPL-3.0-or-later
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "mkdocs2confluence"
3
- version = "0.7.11"
3
+ version = "0.7.13"
4
4
  description = "Publish MkDocs Material pages to Confluence Cloud — admonitions, Mermaid diagrams, tabs, page properties and more"
5
5
  readme = "README.md"
6
6
  license = { text = "GPL-3.0-or-later" }
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mkdocs2confluence
3
- Version: 0.7.11
3
+ Version: 0.7.13
4
4
  Summary: Publish MkDocs Material pages to Confluence Cloud — admonitions, Mermaid diagrams, tabs, page properties and more
5
5
  Author: Anders Hybertz
6
6
  License: GPL-3.0-or-later
@@ -576,25 +576,21 @@ def _emit_abbrev_footnote(node: AbbrevFootnoteNode) -> str:
576
576
 
577
577
  def _emit_abbrev_glossary_block(node: AbbrevGlossaryBlock) -> str:
578
578
  """End-of-page abbreviations list with Confluence anchor targets."""
579
- parts: list[str] = ["<hr />\n<h6>Abbreviations</h6>\n"]
580
- if node.footnoted:
581
- parts.append("<ol>\n")
582
- for fn in node.footnoted:
583
- anchor = html.escape(f"abbr-{fn.number}")
584
- anchor_macro = (
585
- f'<ac:structured-macro ac:name="anchor">'
586
- f'<ac:parameter ac:name=""><![CDATA[{anchor}]]></ac:parameter>'
587
- f"</ac:structured-macro>"
588
- )
589
- abbr = html.escape(fn.abbr)
590
- defn = html.escape(fn.definition)
591
- parts.append(f"<li>{anchor_macro}<strong>{abbr}</strong>{defn}</li>\n")
592
- parts.append("</ol>\n")
593
- if node.extras:
594
- parts.append("<ul>\n")
595
- for abbr, defn in node.extras:
596
- parts.append(f"<li><strong>{html.escape(abbr)}</strong> — {html.escape(defn)}</li>\n")
597
- parts.append("</ul>\n")
579
+ parts: list[str] = ["<hr />\n<h6>Abbreviations</h6>\n<ol>\n"]
580
+ for fn in node.footnoted:
581
+ anchor = html.escape(f"abbr-{fn.number}")
582
+ anchor_macro = (
583
+ f'<ac:structured-macro ac:name="anchor">'
584
+ f'<ac:parameter ac:name=""><![CDATA[{anchor}]]></ac:parameter>'
585
+ f"</ac:structured-macro>"
586
+ )
587
+ abbr = html.escape(fn.abbr)
588
+ defn = html.escape(fn.definition)
589
+ parts.append(f"<li>{anchor_macro}<strong>{abbr}</strong> {defn}</li>\n")
590
+ for abbr, defn in node.extras:
591
+ # No anchor these only appeared in headings/titles, no inline superscript links here.
592
+ parts.append(f"<li><strong>{html.escape(abbr)}</strong> — {html.escape(defn)}</li>\n")
593
+ parts.append("</ol>\n")
598
594
  return "".join(parts)
599
595
 
600
596
 
@@ -35,6 +35,7 @@ from mkdocs_to_confluence.ir.nodes import (
35
35
  BlockQuote,
36
36
  BoldNode,
37
37
  BulletList,
38
+ CodeBlock,
38
39
  ContentTabs,
39
40
  Expandable,
40
41
  IRNode,
@@ -52,6 +53,12 @@ from mkdocs_to_confluence.ir.nodes import (
52
53
  TextNode,
53
54
  )
54
55
 
56
+ # Block node types that can appear as direct children of a ListItem in a loose list.
57
+ _BLOCK_TYPES = (
58
+ Section, Paragraph, CodeBlock, Admonition,
59
+ BulletList, OrderedList, Table, BlockQuote, ContentTabs, Expandable,
60
+ )
61
+
55
62
  # ── Internal state ────────────────────────────────────────────────────────────
56
63
 
57
64
 
@@ -148,7 +155,12 @@ def _transform_block(node: IRNode, state: _State) -> IRNode:
148
155
 
149
156
 
150
157
  def _transform_list_item(item: ListItem, state: _State) -> ListItem:
151
- new_children = tuple(_transform_block(c, state) for c in item.children)
158
+ if any(isinstance(c, _BLOCK_TYPES) for c in item.children):
159
+ # Loose item: children are block nodes (paragraphs, nested lists, etc.)
160
+ new_children = tuple(_transform_block(c, state) for c in item.children)
161
+ else:
162
+ # Tight item: children are inline nodes — expand directly.
163
+ new_children = _inline(item.children, state, safe=True)
152
164
  return replace(item, children=new_children)
153
165
 
154
166
 
@@ -234,3 +234,23 @@ def test_extras_sorted_alphabetically():
234
234
  assert isinstance(glossary, AbbrevGlossaryBlock)
235
235
  extra_abbrs = [abbr for abbr, _ in glossary.extras]
236
236
  assert extra_abbrs == sorted(extra_abbrs)
237
+
238
+
239
+ def test_expands_in_tight_list_item():
240
+ from mkdocs_to_confluence.ir.nodes import BulletList, ListItem
241
+ abbrevs = {"API": "Application Programming Interface"}
242
+ item = ListItem(children=(TextNode("Use the API here."),))
243
+ nodes = (BulletList(items=(item,)),)
244
+ result = apply_abbreviations(nodes, abbrevs, page_text="Use the API here.")
245
+ item_children = result[0].items[0].children # type: ignore[union-attr]
246
+ assert any(isinstance(c, AbbrevFootnoteNode) and c.abbr == "API" for c in item_children)
247
+
248
+
249
+ def test_expands_in_loose_list_item():
250
+ from mkdocs_to_confluence.ir.nodes import BulletList, ListItem
251
+ abbrevs = {"API": "Application Programming Interface"}
252
+ item = ListItem(children=(Paragraph(children=(TextNode("Use the API here."),)),))
253
+ nodes = (BulletList(items=(item,)),)
254
+ result = apply_abbreviations(nodes, abbrevs, page_text="Use the API here.")
255
+ para_children = result[0].items[0].children[0].children # type: ignore[union-attr]
256
+ assert any(isinstance(c, AbbrevFootnoteNode) and c.abbr == "API" for c in para_children)
@@ -402,6 +402,24 @@ class TestFootnoteEmitter:
402
402
  assert 'fn-1' in html_out
403
403
  assert 'My note.' in html_out
404
404
 
405
+ def test_abbrev_glossary_extras_in_ol_not_ul(self) -> None:
406
+ """Abbreviations only in headings/titles must appear in <ol>, not <ul>."""
407
+ from mkdocs_to_confluence.emitter.xhtml import emit
408
+ from mkdocs_to_confluence.ir.nodes import AbbrevFootnoteNode, AbbrevGlossaryBlock
409
+ fn = AbbrevFootnoteNode(abbr="API", definition="Application Programming Interface", number=1)
410
+ block = AbbrevGlossaryBlock(
411
+ footnoted=(fn,),
412
+ extras=(("AD", "Active Directory"),),
413
+ )
414
+ out = emit((block,))
415
+ assert "<ol>" in out
416
+ assert "<ul>" not in out
417
+ assert "AD" in out
418
+ assert "Active Directory" in out
419
+ assert "API" in out
420
+ # extras must NOT get an anchor macro
421
+ assert out.count('ac:name="anchor"') == 1 # only for the footnoted entry
422
+
405
423
 
406
424
  # ── Inline HTML emitters ──────────────────────────────────────────────────────
407
425