Configuration¶
There are a number of options for configuring your site’s look and feel.
All configuration options are passed with the html_theme_options
variable
in your conf.py
file. This is a dictionary with key: val
pairs that
you can configure in various ways. This page describes the options available to you.
Configure project logo¶
To add a logo that’s placed at the left of your nav bar, put a logo file under your doc path’s _static folder, and use the following configuration:
html_logo = "_static/logo.png"
The logo links to master_doc
(usually the first page of your documentation) by default.
If you’d like it to link to another page or use an external link instead, use the following configuration:
html_theme_options = {
"logo_link": "<other page or external link>"
}
Configure icon links¶
If you’d like icon links to show up to the right of your main navigation bar, use the following configuration:
html_theme_options = {
...
"icon_links": [
{
"name": "GitHub",
"url": "https://github.com/<your-org>/<your-repo>",
"icon": "fab fa-github-square",
},
{
"name": "GitLab",
"url": "https://gitlab.com/<your-org>/<your-repo>",
"icon": "fab fa-gitlab",
},
{
"name": "Twitter",
"url": "https://twitter.com/<your-handle>",
"icon": "fab fa-twitter-square",
},
],
...
}
The value of icon
can be any full
FontAwesome 5 Free icon.
In addition to the main icon class, e.g. fa-cat
, the “style” class must
also be provided e.g. fab for branding, or fas for solid.
Hint
To get custom colors like “Twitter blue”, use the following in your CSS,
e.g. custom.css
:
i.fa-twitter-square:before {
color: #55acee;
}
This has already been added for the brands that have shortcuts.
The below are shortcuts for commonly-used services, but may be removed in a future
release in favor of icon_links
:
html_theme_options = {
...
"github_url": "https://github.com/<your-org>/<your-repo>",
"gitlab_url": "https://gitlab.com/<your-org>/<your-repo>",
"twitter_url": "https://twitter.com/<your-handle>",
...
}
Additionally, the screen-reader accessible label for this menu can be configured:
html_theme_options = {
...
"icon_links_label": "Quick Links",
...
}
Configure the sidebar¶
pydata_sphinx_theme
provides two new sidebar items by default:
sidebar-nav-bs.html
- a bootstrap-friendly navigation sectionsidebar-search-bs.html
- a bootstrap-friendly search bar
By default, this theme’s sidebar has these two elements in it. If you’d like to override this behavior and control the sidebar on a per-page basis, use the Sphinx html-sidebars configuration value.
Hiding the previous and next buttons¶
By default, each page of your site will have “previous” and “next” buttons at the bottom. You can hide these buttons with the following configuration:
html_theme_options = {
"show_prev_next": False
}
Add an Edit this Page button¶
You can add a button to each page that will allow users to edit the page text
directly and submit a pull request to update the documentation. To include this
button in the right sidebar of each page, add the following configuration to
your conf.py
file:
html_context = {
"github_user": "<your-github-org>",
"github_repo": "<your-github-repo>",
"github_version": "<your-branch>",
"doc_path": "<path-from-root-to-your-docs>",
}
You should also enable the edit option in your ‘html_theme_options’:
html_theme_options = {
"use_edit_page_button": True,
}
Optionally, if you have a self-hosted Github Enterprise instance, you can configure a custom url. This option defaults to ‘https://github.com’, and you do not need to specify it if you wish to use the default.
html_context = {
"github_url": "<your-github-url>",
}
Configure the search bar position¶
To modify the position of the search bar, change the following variable in
your configuration file conf.py
. Possible options are ‘navbar’ and ‘sidebar’.
By default the search bar is positioned in the sidebar since this is more suitable for large navigation bars.
html_theme_options = {
"search_bar_position": "navbar"
}
Configure the search bar text¶
To modify the text that is in the search bar before people click on it, add the
following configuration to your conf.py
file:
html_theme_options = {
"search_bar_text": "Your text here..."
}
Google Analytics¶
If the google_analytics_id
config option is specified (like UA-XXXXXXX
),
Google Analytics’ javascript is included in the html pages.
html_theme_options = {
"google_analytics_id": "UA-XXXXXXX",
}
Changing pages with keyboard presses¶
By default, pydata-sphinx-theme
allows users to move to the previous/next
page using the left/right arrow keys on a keyboard. To disable this behavior,
use the following configuration:
html_theme_options = {
"navigation_with_keys": False
}
Show more levels of the in-page TOC by default¶
Normally only the 2nd-level headers of a page are show in the right table of contents, and deeper levels are only shown when they are part of an active section (when it is scrolled on screen).
You can show deeper levels by default by using the following configuration, indicating how many levels should be displayed:
html_theme_options = {
"show_toc_level": 2
}
All headings up to and including the level specified will now be shown regardless of what is displayed on the page.
Remove the sidebar from some pages¶
If you’d like the left sidebar to be removed from a page, you can use the
following configuration in conf.py
:
html_sidebars = {
"pagename": []
}
This works for glob-style patterns as well. For example:
html_sidebars = {
"folder/*": []
}
If you’d like to remove the left sidebar from all pages of your documentation, use this pattern:
html_sidebars = {
"**": []
}
For information about configuring the sidebar’s contents, see Configure the sidebar.