diff --git a/nbconvert/exporters/templateexporter.py b/nbconvert/exporters/templateexporter.py index 6b1d66202..2575af427 100644 --- a/nbconvert/exporters/templateexporter.py +++ b/nbconvert/exporters/templateexporter.py @@ -203,10 +203,10 @@ def default_config(self): enable_async = Bool(False, help="Enable Jinja async template execution").tag( affects_environment=True ) - - include_tableofcontents = Bool(False, allow_none=True, help="Enable to include a table of contents").tag( - config=True, affects_template=True - ) + + include_tableofcontents = Bool( + False, allow_none=True, help="Enable to include a table of contents" + ).tag(config=True, affects_template=True) _last_template_file = "" _raw_template_key = "" @@ -686,5 +686,3 @@ def _init_resources(self, resources): resources["deprecated"] = deprecated resources["include_tableofcontents"] = self.include_tableofcontents return resources - - diff --git a/nbconvert/filters/markdown_mistune.py b/nbconvert/filters/markdown_mistune.py index c1889f06e..a79ed635e 100644 --- a/nbconvert/filters/markdown_mistune.py +++ b/nbconvert/filters/markdown_mistune.py @@ -485,6 +485,7 @@ def render(self, source: str) -> str: """Render the HTML output for a Markdown source.""" return str(super().__call__(source)) + def markdown2html_mistune(source: str) -> str: """Convert a markdown string to HTML using mistune""" return MarkdownWithMath(renderer=IPythonRenderer(escape=False)).render(source) @@ -500,6 +501,7 @@ def heading(self, text, level): self.headings.append((level, text)) return "" # We return an empty string to avoid outputting the headings + def extract_titles_from_markdown_input(markdown_input): # Markdown_input is a single string with all the markdown content concatenated # Initiate list of titles @@ -515,12 +517,15 @@ def extract_titles_from_markdown_input(markdown_input): extract_titles(markdown_input) # Extracted headings - for level, title in renderer.headings: # renderer.headings is an array for each markdown element + for ( + level, + title, + ) in renderer.headings: # renderer.headings is an array for each markdown element children = title["children"] attrs = title["attrs"] raw_text = children[0]["raw"] level = attrs["level"] - id = raw_text.replace(' ', '-') - href= "#" + id + id = raw_text.replace(" ", "-") + href = "#" + id titles_array.append([level, raw_text, id, href]) return titles_array diff --git a/share/templates/lab/index.html.j2 b/share/templates/lab/index.html.j2 index ed33dd5ed..cfc863bac 100644 --- a/share/templates/lab/index.html.j2 +++ b/share/templates/lab/index.html.j2 @@ -187,7 +187,7 @@ a.anchor-link { {{text}} -{%- endif -%} +{%- endif -%} {%- if level==2 -%}