Skip to content

Commit

Permalink
Drop usage of internal API when conditionally including assets
Browse files Browse the repository at this point in the history
Fixes #197 by reversing the logic of how JS/CSS assets are added to pages.
Rather than adding assets to the app and using undocumented API to *remove* them when not needed, do the exact opposite and only add them to the local html-page-context when building a page.

Signed-off-by: Benjamin Cabé <[email protected]>
  • Loading branch information
kartben committed Aug 20, 2024
1 parent e83dc14 commit b74556f
Showing 1 changed file with 19 additions and 30 deletions.
49 changes: 19 additions & 30 deletions sphinx_tabs/tabs.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,13 @@
from sphinx.directives.code import CodeBlock


FILES = [
JS_FILES = [
"tabs.js",
"tabs.css",
]

CSS_FILES = [
"tabs.css",
]

LEXER_MAP = {}
for lexer in get_all_lexers():
Expand Down Expand Up @@ -295,21 +297,6 @@ def found_tabs_directive(self):
return self._found


def update_config(app, config):
"""Adds sphinx-tabs CSS and JS asset files"""
for path in [Path(path) for path in FILES]:
if not config.sphinx_tabs_disable_css_loading and path.suffix == ".css":
if "add_css_file" in dir(app):
app.add_css_file(path.as_posix())
else:
app.add_stylesheet(path.as_posix())
if path.suffix == ".js":
if "add_script_file" in dir(app):
app.add_script_file(path.as_posix())
else:
app.add_js_file(path.as_posix())


# pylint: disable=unused-argument
def update_context(app, pagename, templatename, context, doctree):
"""Remove sphinx-tabs CSS and JS asset files if not used in a page"""
Expand All @@ -322,18 +309,21 @@ def update_context(app, pagename, templatename, context, doctree):
if sphinx.version_info >= (4, 1, 0):
include_assets_in_all_pages = app.registry.html_assets_policy == "always"

if not visitor.found_tabs_directive and not include_assets_in_all_pages:
paths = [Path("_static") / f for f in FILES]
if "css_files" in context:
context["css_files"][:] = context["css_files"]
for path in paths:
if path.suffix == ".css" and path in context["css_files"]:
context["css_files"].remove(path.as_posix())
if "script_files" in context:
context["script_files"][:] = context["script_files"]
for path in paths:
if path.suffix == ".js" and path.as_posix() in context["script_files"]:
context["script_files"].remove(path.as_posix())
if visitor.found_tabs_directive or include_assets_in_all_pages:
if not app.config.sphinx_tabs_disable_css_loading:
for css in CSS_FILES:
if "add_css_file" in dir(app):
app.add_css_file(css)
else:
# support old Sphinx versions
app.add_stylesheet(css)

for js in JS_FILES:
if "add_script_file" in dir(app):
app.add_js_file(js)
else:
# support old Sphinx versions
app.add_script_file(js)


# pylint: enable=unused-argument
Expand All @@ -357,7 +347,6 @@ def setup(app):
"builder-inited",
(lambda app: app.config.html_static_path.insert(0, static_dir.as_posix())),
)
app.connect("config-inited", update_config)
app.connect("html-page-context", update_context)

return {
Expand Down

0 comments on commit b74556f

Please sign in to comment.