From 95e0311d6a433a6d7b002fedfb09af31e2d34f45 Mon Sep 17 00:00:00 2001 From: M Bussonnier Date: Mon, 17 Jun 2024 09:28:17 -0700 Subject: [PATCH] MAINT: simpleify _generate_header_nav_before_dropdown (#1883) don't rely on string replacement which should make things a bit safer in the long run. closes #1882 --- src/pydata_sphinx_theme/toctree.py | 46 ++++++++++++++++-------------- 1 file changed, 25 insertions(+), 21 deletions(-) diff --git a/src/pydata_sphinx_theme/toctree.py b/src/pydata_sphinx_theme/toctree.py index d01519dbb..15f22eae0 100644 --- a/src/pydata_sphinx_theme/toctree.py +++ b/src/pydata_sphinx_theme/toctree.py @@ -219,40 +219,44 @@ def _generate_header_nav_before_dropdown( links_data = _generate_nav_info() links_html = [] - boilerplate = """ + links_dropdown = [] + boilerplate = dedent( + """
  • {title}
  • """ + ) nav_item = "nav-item" nav_link = "nav-link" - for link in links_data: + dropdown_item = "dropdown-item" + for link in links_data[:n_links_before_dropdown]: links_html.append( - dedent( - boilerplate.format( - active=" current active" if link.is_current else "", - nav_link=nav_link, - nav_item=nav_item, - ext_int="external" if link.is_external else "internal", - href=link.href, - title=link.title, - ) + boilerplate.format( + active="current active" if link.is_current else "", + nav_link=nav_link, + nav_item=nav_item, + ext_int="external" if link.is_external else "internal", + href=link.href, + title=link.title, + ) + ) + for link in links_data[n_links_before_dropdown:]: + links_dropdown.append( + boilerplate.format( + active="current active" if link.is_current else "", + nav_link=nav_link + " " + dropdown_item, + nav_item="", + ext_int="external" if link.is_external else "internal", + href=link.href, + title=link.title, ) ) # The first links will always be visible - links_solo = links_html[:n_links_before_dropdown] - out = "\n".join(links_solo) - - # Wrap the final few header items in a "more" dropdown - links_dropdown = [ - html.replace(nav_item, "").replace(nav_link, "nav-link dropdown-item") - for html in links_html[n_links_before_dropdown:] - ] - - return out, links_dropdown + return "\n".join(links_html), links_dropdown def generate_header_nav_html( n_links_before_dropdown: int = 5, dropdown_text: str = "More"