This is the official Sphinx theme for Matplotlib documentation. It extends the
pydata-sphinx-theme
project, but adds custom styling and a navigation bar.
A demo of the theme built with the main
branch can be seen at
https://matplotlib.org/mpl-sphinx-theme/.
When creating a Matplotlib subproject you can include this theme by changing this
line in your conf.py
file
html_theme = 'mpl_sphinx_theme'
And by including mpl_sphinx_theme
as a requirement in your documentation
installation.
See the docs/conf.py
file for other settings.
There are two main templates that replace the defaults in pydata-sphinx-theme
:
navbar_center = mpl_nav_bar.html navbar_end = mpl_icon_links.html
Note that the logo options need not be specified as they are included in theme
initialization. The logo is stored at
mpl_sphinx_theme/static/logo_{light,dark}.svg
.
To change the top navbar, edit mpl_sphinx_theme/mpl_nav_bar.html
To change the social icons, edit mpl_sphinx_theme/mpl_icon_links.html
To change the style, edit mpl_sphinx_theme/static/css/style.css
To build the theme with a sample page, navigate into the doc/
directory and run
make html
The built html pages can be found in doc/_build/html/
Manually for now... see the todo below for how we hope to eventually do it automagically.
- be sure to edit mpl_sphinx_theme/_version.py
$ git checkout <commit-hash> $ git tag -a x.y.z -m 'Version x.y.z' $ git push upstream main --tags $ python -m build -s -w $ twine upload dist/mpl_sphinx_theme-x.y.z*
TODO: This project uses GitHub Actions
to automatically push a new release to PyPI whenever
a git tag is pushed. For example, to release a new x.y.z
version of
mpl-sphinx-theme
, checkout the commit you would like to release,
add a git tag, and push the tag to the main
branch of the
matplotlib/mpl-sphinx-theme
repository:
TODO: After a new release is published on PyPI, a pull request to the mpl-sphinx-theme
conda-forge feedstock
for the new x.y.z
release will automatically be opened by conda-forge bots.