Custom Sphinx configuration¶
Jupyter Book uses the excellent documentation tool Sphinx to build your book and manage citations, cross-references, and extensibility.
While Jupyter Book comes pre-configured with several Sphinx extensions, power-users may wish to add their own extensions and configuration. This page describes how to do so.
Warning
Adding your own Sphinx configuration and extensions may cause Jupyter Book to behave unpredictably. Use at your own risk!
Custom Sphinx extensions¶
To enable your own Sphinx extensions when building a Jupyter Book, use the following
configuration in your _config.yml
file:
sphinx:
extra_extensions:
- extension1
- extension2
Any extensions that are listed will be appended to the list of Sphinx extensions at build time.
Note
Make sure that you have your extension installed on your machine, or Sphinx won’t know how to build the extensions.
An example: sphinx-tabs
¶
For example, let’s say you’d like to include tabbed content in your book. There is a Sphinx extension for that. To enable it, we’ll do the following:
Install
sphinx-tabs
. Here’s the command to do so:pip install sphinx-tabs
Add
sphinx-tabs
content to your book. Here’s an example with MyST Markdown:````{tabs} ```{tab} Line one Beautiful is better than ugly. ✨ ``` ```{tab} Line two Explicit is better than implicit. ❗ ``` ```{tab} Line three Simple is better than complex. 😵 ``` ````
Activate
sphinx-tabs
in_config.yml
. Thesphinx-tabs
documentation says we activate it in Sphinx by addingextensions = ["sphinx_tabs.tabs"]
, so we’ll add it to our Jupyter Book like so:sphinx: extra_extensions: - sphinx_tabs.tabs
Now, Jupyter Book will know how to interpret the {tabs}
directive
(and any other directives that sphinx-tabs
supports).
For example, here is a rendered version of the tab code pasted above:
The Zen of Python, in 3 tabs.
Beautiful is better than ugly. ✨
Explicit is better than implicit. ❗
Simple is better than complex. 😵
Custom CSS or JavaScript¶
If you’d like to include custom CSS rules or JavaScript scripts in your book,
you can do so by adding them to a folder called _static
in your book’s folder.
Any files that end in .css
or .js
in this folder will automatically be copied
into your built book HTML and linked in the header of each page.
For example, to include a custom CSS file myfile.css
in a Jupyter Book folder with
the following structure:
mybook/
├── _config.yml
├── _toc.yml
└── page1.md
Add the static file here:
├── _config.yml
├── _toc.yml
├── page1.md
└── _static
└── myfile.css
The rules should then automatically be applied to your site. In general, these CSS and JS files will be loaded after others are loaded on your page, so they should overwrite pre-existing rules and behaviour.
An example: justify the text¶
If you want the text of you book to be justified instead of left aligned then create myfile.css
under mybook/_static
with the following CSS:
p {
text-align: justify;
}
Manual Sphinx configuration¶
You may also directly override the key-value pairs that Sphinx normally has
you configure in conf.py
. To do so, use the following section of _config.yml
:
sphinx:
config:
key1: value1
key2: value2
Warning
Any options set in this section will override default configurations set by Jupyter Book. Use at your own risk!
Tip
If you wish to inspect a conf.py
representation of the generated configuration,
which Jupyter Book will pass to Sphinx, you can run from the command-line:
jb config sphinx mybookname/
Fine control of parsing and execution¶
As discussed in the components of Jupyter Book, two of the main components of Jupyter Book are Sphinx extensions; MyST-Parser for Markdown parsing, and MyST-NB for notebook execution and output rendering.
These two extensions are highly customizable via Sphinx configuration.
Some of their configuration is already exposed in the _config.yml
, but you can also directly set configuration, see:
Defining TeX macros¶
You can add LaTeX macros for the whole book by defining them under the Macros
option of the TeX
block. For example, the following two macros have been pre-defined in the Sphinx configuration
sphinx:
config:
mathjax_config:
TeX:
Macros:
"N": "\\mathbb{N}"
"floor": ["\\lfloor#1\\rfloor", 1]
"bmat" : ["\\left[\\begin{array}"]
"emat" : ["\\end{array}\\right]"]
You can also define TeX macros for a specific file by introducing them at the beginning of the file under a math
directive. For example
```{math}
\newcommand\N{\mathbb{N}}
\newcommand\floor[1]{\lfloor#1\rfloor}
\newcommand{\bmat}{\left[\begin{array}}
\newcommand{\emat}{\end{array}\right]}
```
The commands can be used inside a math
directive, $$
, or in-line $
. For example,
$$
A = \bmat{} 1 & 1 \\ 2 & 1\\ 3 & 2 \emat{},\ b=\bmat{} 2\\ 3 \\ 4\emat{},\ \gamma = 0.5
$$
will be rendered as:
See also
How MyST-Parser works with MathJax, and the section on math and equations.
Important
To have “bare” LaTeX rendered in HTML, you must either set in your _config.yml
:
parse:
myst_extended_syntax: true
or more specifically:
sphinx:
config:
myst_amsmath_enable: true
Then you can include:
\begin{equation}
\int_0^\infty \frac{x^3}{e^x-1}\,dx = \frac{\pi^4}{15}
\end{equation}
which renders as