【问题标题】:Enable versions in sidebar in sphinx read the docs theme在 sphinx 的侧边栏中启用版本阅读文档主题
【发布时间】:2018-03-17 02:26:01
【问题描述】:

我想在侧边栏中包含versions.html,但未能成功。

我尝试在 ** 中为侧边栏添加versions.html,但没有效果:

html_sidebars = {
    '**': ['versions.html']
}

还有如何在conf.py中声明不同的版本。

我查看了sphinxcontrib-versioning,但这并不是我想要的。

【问题讨论】:

  • 你说的是左下角的那个小弹出窗口吗? docs.readthedocs.io/en/latest你用的是 RTD 主题吗?
  • 是的,完全正确。但自托管不在 rtd 网站上
  • 渲染后,检查浏览器的开发者工具,看看是否有任何东西被阻塞。如果一切都加载了,渲染的 HTML 代码以及 JS 和 CSS 资产是否与 RTD 的示例一致?如果没有,那么您可能需要在本地安装 RTD,因为这可能特定于该环境。源代码:github.com/rtfd/readthedocs.org
  • 谢谢。我一直在查看渲染页面的源代码,它似乎不包括侧边栏。所以,我认为这是一个狮身人面像或主题问题。
  • 由于它不包括侧边栏,因此从逻辑上讲,此功能需要您安装 readthedocs.org 应用程序,因为它是您系统中唯一缺少的部分。也就是说,当然,您还有其他严重错误,但我怀疑您是否可以成功构建文档。无论主题如何,Sphinx 本身一次只能生成一个版本的文档。

标签: python-sphinx read-the-docs


【解决方案1】:

这可以通过添加_templates/versions.html 文件来覆盖rtd 主题的默认jinja template file 并在conf.py 文件中添加一些变量来实现。

执行以下命令创建一个新的 '_templates/' 目录和 'versions.html' 文件:

mkdir _templates
cat > _templates/versions.html <<'EOF'
{% if READTHEDOCS or display_lower_left %}
{# Add rst-badge after rst-versions for small badge style. #}
  <div class="rst-versions" data-toggle="rst-versions" role="note" aria-label="versions">
    <span class="rst-current-version" data-toggle="rst-current-version">
      <span class="fa fa-book"> Read the Docs</span>
      v: {{ current_version }}
      <span class="fa fa-caret-down"></span>
    </span>
    <div class="rst-other-versions">
      {% if languages|length >= 1 %}
      <dl>
        <dt>{{ _('Languages') }}</dt>
        {% for slug, url in languages %}
          {% if slug == current_language %} <strong> {% endif %}
          <dd><a href="{{ url }}">{{ slug }}</a></dd>
          {% if slug == current_language %} </strong> {% endif %}
        {% endfor %}
      </dl>
      {% endif %}
      {% if versions|length >= 1 %}
      <dl>
        <dt>{{ _('Versions') }}</dt>
        {% for slug, url in versions %}
          {% if slug == current_version %} <strong> {% endif %}
          <dd><a href="{{ url }}">{{ slug }}</a></dd>
          {% if slug == current_version %} </strong> {% endif %}
        {% endfor %}
      </dl>
      {% endif %}
      {% if downloads|length >= 1 %}
      <dl>
        <dt>{{ _('Downloads') }}</dt>
        {% for type, url in downloads %}
          <dd><a href="{{ url }}">{{ type }}</a></dd>
        {% endfor %}
      </dl>
      {% endif %}
      {% if READTHEDOCS %}
      <dl>
        <dt>{{ _('On Read the Docs') }}</dt>
          <dd>
            <a href="//{{ PRODUCTION_DOMAIN }}/projects/{{ slug }}/?fromdocs={{ slug }}">{{ _('Project Home') }}</a>
          </dd>
          <dd>
            <a href="//{{ PRODUCTION_DOMAIN }}/builds/{{ slug }}/?fromdocs={{ slug }}">{{ _('Builds') }}</a>
          </dd>
      </dl>
      {% endif %}
      <hr/>
      {% trans %}Free document hosting provided by <a href="http://www.readthedocs.org">Read the Docs</a>.{% endtrans %}
 
    </div>
  </div>
{% endif %}
 
EOF

并执行以下操作以追加到conf.py 文件:

cat >> conf.py <<'EOF'
 
############################
# SETUP THE RTD LOWER-LEFT #
############################
try:
   html_context
except NameError:
   html_context = dict()
html_context['display_lower_left'] = True

templates_path = ['_templates']

if 'REPO_NAME' in os.environ:
   REPO_NAME = os.environ['REPO_NAME']
else:
   REPO_NAME = ''
 
# SET CURRENT_LANGUAGE
if 'current_language' in os.environ:
   # get the current_language env var set by buildDocs.sh
   current_language = os.environ['current_language']
else:
   # the user is probably doing `make html`
   # set this build's current language to english
   current_language = 'en'
 
# tell the theme which language to we're currently building
html_context['current_language'] = current_language
 
# SET CURRENT_VERSION
from git import Repo
repo = Repo( search_parent_directories=True )
 
if 'current_version' in os.environ:
   # get the current_version env var set by buildDocs.sh
   current_version = os.environ['current_version']
else:
   # the user is probably doing `make html`
   # set this build's current version by looking at the branch
   current_version = repo.active_branch.name
 
# tell the theme which version we're currently on ('current_version' affects
# the lower-left rtd menu and 'version' affects the logo-area version)
html_context['current_version'] = current_version
html_context['version'] = current_version
 
# POPULATE LINKS TO OTHER LANGUAGES
html_context['languages'] = [ ('en', '/' +REPO_NAME+ '/en/' +current_version+ '/') ]
 
languages = [lang.name for lang in os.scandir('locales') if lang.is_dir()]
for lang in languages:
   html_context['languages'].append( (lang, '/' +REPO_NAME+ '/' +lang+ '/' +current_version+ '/') )
 
# POPULATE LINKS TO OTHER VERSIONS
html_context['versions'] = list()
 
versions = [branch.name for branch in repo.branches]
for version in versions:
   html_context['versions'].append( (version, '/' +REPO_NAME+ '/'  +current_language+ '/' +version+ '/') )
 
# POPULATE LINKS TO OTHER FORMATS/DOWNLOADS
 
# settings for creating PDF with rinoh
rinoh_documents = [(
 master_doc,
 'target',
 project+ ' Documentation',
 '© ' +copyright,
)]
today_fmt = "%B %d, %Y"
 
# settings for EPUB
epub_basename = 'target'
 
html_context['downloads'] = list()
html_context['downloads'].append( ('pdf', '/' +REPO_NAME+ '/' +current_language+ '/' +current_version+ '/' +project+ '-docs_' +current_language+ '_' +current_version+ '.pdf') )
 
html_context['downloads'].append( ('epub', '/' +REPO_NAME+ '/' +current_language+ '/' +current_version+ '/' +project+ '-docs_' +current_language+ '_' +current_version+ '.epub') )
 
EOF

查看此网站的示例:

可以从以下 GitHub 存储库查看(并轻松分叉)创建上述站点的整个配置:

有关我如何设置的更多信息,请参阅article on how to setup the lower-left Read the Docs menu for navigation between languages and versions and downloads

【讨论】:

  • 很好,效果很好。我编辑了 conf.py 以添加缺少的模板声明
【解决方案2】:

如果上述解决方案不适合任何人,我可以使用此扩展程序添加版本控制。 sphinx-multiversion。我的文档设置是 sphinx,带有 read-the-docs-theme 以及 Azure Dev Ops 上的文档的私有 repo。结果与上面的代码 sn-p 相同。有关所有工作部分,请参阅安装、快速入门、配置和模板页面。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-01-06
    • 1970-01-01
    • 2014-06-06
    • 2013-02-21
    • 1970-01-01
    • 1970-01-01
    • 2013-12-13
    相关资源
    最近更新 更多