Включить версии на боковой панели в sphinx, прочтите тему документов

Я хотел бы включить файл versions.html в боковую панель, но мне это не удалось.

Я пробовал добавить файл versions.html в ** для боковых панелей, это не дало результата:

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

Также как объявить разные версии в conf.py.

Я просмотрел sphinxcontrib-versioning, но это не совсем то, что я ищу.


person Denis Rouzaud    schedule 17.03.2018    source источник
comment
Вы говорите об этом маленьком всплывающем окне в нижнем левом углу? docs.readthedocs.io/en/latest Используете ли вы тему RTD?   -  person Steve Piercy    schedule 17.03.2018
comment
Да, точно. Но самообслуживание не на сайте rtd   -  person Denis Rouzaud    schedule 17.03.2018
comment
После рендеринга проверьте инструменты разработчика браузера, чтобы увидеть, не заблокировано ли что-нибудь. Если все загружается, соответствует ли визуализированный HTML-код, а также ресурсы JS и CSS примеру RTD? В противном случае вам может потребоваться установить RTD локально, потому что это может быть специфическим для данной среды. Исходный код: github.com/rtfd/readthedocs.org   -  person Steve Piercy    schedule 18.03.2018
comment
Спасибо. Я искал исходный код отображаемой страницы, и, похоже, он не включает боковую панель. Так что, я думаю, это скорее проблема сфинкса или темы.   -  person Denis Rouzaud    schedule 18.03.2018
comment
Поскольку это не включает в себя боковую панель, то логически эта функция требует, чтобы вы установили приложение readthedocs.org, поскольку это единственная недостающая часть в вашей системе. Конечно, у вас есть еще кое-что ужасно неправильное, но я сомневаюсь, что иначе вы сможете успешно создавать свои документы. Сам Sphinx может генерировать только одну версию документации за раз, независимо от темы.   -  person Steve Piercy    schedule 18.03.2018
comment
по всей видимости, это не представляется возможным. Для этого был запрос на вытягивание, но он не был объединен.   -  person Denis Rouzaud    schedule 19.03.2018
comment
Разветвите его, создайте новую функциональную ветку и перенесите изменения из PR в вашу локальную функциональную ветку. Выполнено!   -  person Steve Piercy    schedule 19.03.2018


Ответы (2)


Этого можно добиться, добавив файл _templates/versions.html, чтобы переопределить файл шаблона jinja по умолчанию для темы rtd. и добавив несколько переменных в 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:

Для получения дополнительной информации о том, как я это настроил, см. статья о том, как настроить левый нижний угол. Прочтите меню Документов для навигации между языками, версиями и загрузками.

person Michael Altfield    schedule 23.07.2020
comment
хорошо, это сработало. Я отредактировал conf.py, чтобы добавить объявление отсутствующих шаблонов - person Denis Rouzaud; 03.08.2020

Если вышеприведенное решение никому не подходит, я смог использовать это расширение для добавления управления версиями. сфинкс-мультиверсия. Моя документация настроена на sphinx с темой read-the-docs-theme с частным репозиторием для документов в Azure Dev Ops. Те же результаты, что и в приведенном выше фрагменте кода. См. Все рабочие части на страницах «Установка», «Быстрый запуск», «Конфигурация» и «Шаблоны».

person RedPandaRevolt    schedule 26.05.2021