File: get-started.md

package info (click to toggle)
sphinx-book-theme 1.1.4-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,104 kB
  • sloc: python: 1,302; javascript: 170; makefile: 56; sh: 8
file content (122 lines) | stat: -rw-r--r-- 3,946 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# Get started

This is a short step-by-step tutorial to get started with the Sphinx Book Theme.

:::{note}
This documentation and the examples below are written with MyST Markdown, a form
of markdown that works with Sphinx. For more information about MyST markdown, and
to use MyST markdown with your Sphinx website,
see [the MyST-parser documentation](https://myst-parser.readthedocs.io/)
:::

## Prerequisites

You should be relatively familiar with [the Sphinx ecosystem](http://www.sphinx-doc.org/), and have it installed locally on your computer.

:::{note}
If you don't already have a Sphinx site ready to customize, you can create one with:

```bash
sphinx-quickstart
```
:::

## Install and activate the theme

First install `sphinx-book-theme` with `pip`:

```
pip install sphinx-book-theme
```

then, activate the theme in your Sphinx configuration (`conf.py`):

```
...
html_theme = "sphinx_book_theme"
...
```

This will activate the Sphinx Book Theme for your documentation.

:::{note}
You may need to comment-out your `html_theme_options` configuration depending on your previous theme.
:::

## Add a source repository button to your theme

There are several ways that you can customize the Sphinx Book Theme.
For this tutorial, we'll add a pointer to a GitHub repository for our theme.

To add a button that links to the repository for your documentation, add the following configuration in `conf.py`.

```python
html_theme_options = {
    ...
    "repository_url": "https://github.com/{your-docs-url}",
    "use_repository_button": True,
    ...
}
```

When you build your documentation, your header should now include a small GitHub logo that has a link to the repository.


:::{seealso}
See [](source-files:repository) for more information.
:::

## Customize your left sidebar

There are a few major areas of the page that you can customize with the book theme.
The most common is the **primary sidebar** (by default, on the left of the page).

Sidebar elements are defined as HTML templates by Sphinx, Sphinx extensions, and the current theme.
You may specify which pages should contain which sidebar elements using the `html_sidebars` configuration.
We'll skip this step in this tutorial, but if you'd like to learn more, see [](sidebar-primary:items).

Let's **customize the logo of our site**.
To do so, we'll edit the `html_logo` and `html_title` configuration options.

To add a site logo, follow these steps:

1. Put an image in your documentation's root (e.g., `myimage.png`).
2. Add a line to your `conf.py` file that looks like this:

   ```python
   html_logo = "path/to/myimage.png"
   ```

   Where the path is relative to your `conf.py` file.

Next we'll **customize the title of the site**.
To do so, add a line to your `conf.py` file that looks like this:

```python
html_title = "My site title"
```

This title will now be placed underneath the logo.

## Add some margin content to a page

There are a few special kinds of content that this theme supports, largely inspired by [the Tufte CSS theme styles](https://edwardtufte.github.io/tufte-css/).
One kind of content is **margin content**.
This allows you to "pop out" content to the side of the page, in the margins.
Add some margin content to a page by adding the following directive (written with [MyST Markdown](https://myst-parser.readthedocs.io)).

```{margin} Look, some margin content!
On wider screens, this content will pop out to the side!
```

````md
```{margin} Look, some margin content!
On wider screens, this content will pop out to the side!
```
````

On wide screens, margin content will pop out to the side of the page and allow content underneath it to move upwards.
This allows you to provide extra information without interrupting the flow of information.

There are many other things that you can do with the Sphinx Book Theme.
Now that you've gotten a start, check out the other sections to the left to learn more about how to use it.