File: tutorial.md

package info (click to toggle)
sphinx-theme-builder 0.2.0b2-5
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 448 kB
  • sloc: python: 2,227; sh: 19; makefile: 3
file content (136 lines) | stat: -rw-r--r-- 3,945 bytes parent folder | download
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# Getting Started

Sphinx Theme Builder provides a streamlined workflow for developing Sphinx
themes. This tutorial walks through the process of setting up a new Sphinx
theme, making changes to it and generating PyPI distribution files for it.

This tutorial expects that the reader has working knowledge of:

- Terminal / Command Prompt
- Python virtual environments
- Web technologies (HTML/JS/CSS)
- Git / GitHub

[sphinx]: https://www.sphinx-doc.org/en/master/
[jinja]: https://palletsprojects.com/p/jinja/

## Installation

As a first step, let's install this tool with the `cli` extra, in a clean
virtual environment:

```shell
$ pip install "sphinx-theme-builder[cli]"
```

## Create a new theme

To create a new theme, you can use the `stb new` command.

```shell
$ stb new my-awesome-sphinx-theme
```

```{todo}
Actually write the template that this uses.
```

You will be prompted to answer a few questions. Once they've been answered, this
command will generate a scaffold for your theme in a folder named
`my-awesome-sphinx-theme`.

For the rest of this tutorial, we're going to exclusively work in this
directory, so it's sensible to `cd` into it.

```shell
$ cd my-awesome-sphinx-theme
```

[cookiecutter]: https://cookiecutter.readthedocs.io/
[cruft]: https://github.com/cruft/cruft

## Install the theme

To work with your theme, it is necessary to install it in the virtual
environment. Let's do an editable install, since that's usually what you would
want to do for development.

```shell
$ pip install -e .
```

Note: an editable install with sphinx-theme-builder as backend requires a modern
version of pip (>= 21.3)

## Start the development server

To start a development server, you use the `stb serve` command. It needs a path
to a directory containing Sphinx documentation, so we'll use the demo
documentation that comes as part of the default scaffold:

```shell
$ stb serve docs/
```

This command will do a few things (we'll get to details of this later) and,
after a short delay, opens your default browser to view the built documentation.
Keep this terminal open/running.

The development server simplifies the workflow for seeing how a change affects
the generated documentation fairly straightforward -- save changes to a file,
switch to the browser and the browser will update to reflect those changes.

## Making changes

```{todo}
This requires that the template in `stb new` works, and uses `sphinx-basic-ng`.
```

To try out how the development server handles changes, create a new
`sections/article.html` file in the
`src/{your_package_name}/theme/{your_theme_name}` with the following content:

```jinja
{{ content }}
```

The server should do a few things and the page will automagically reload with
the new page contents.

### How it works

The development server listens for changes in your theme or the documentation
(i.e. when a file is saved/renamed/moved). When it detects that a change has
been made, the server will:

1. Recompile your theme's assets
2. Rebuild the Sphinx documentation it is serving
3. Automagically reload open browser tabs of HTML pages served by it

If the theme's asset compilation or the documentation build (with Sphinx) fails,
the server will print something in the terminal window about the failure.

## Stopping the server

To stop the server, focus on the terminal where the server is running and press
{kbd}`Ctrl`+{kbd}`C`.

## Packaging the theme

When you wish to publish your theme on PyPI, you will need to package your theme
into a few distribution files and upload these files to PyPI. This makes it
possible to install the package for your theme, which can be downloaded and
installed with `pip`.

To generate the distribution files, run:

```shell
$ stb package
```

This will generate files in `dist/`, that contain the relevant distribution
files for your project. These can be uploaded to PyPI using {pypi}`twine`.

## Next Steps

Go write a Sphinx theme!