This textbook was built with Jupyter Books. This README was written by Shahzar.
Only three files/directories need to be edited.
_config.yml
: Configuration information about the textbook. Modify this file for things like:- changing the logo or favicon;
- adding or removing launch buttons;
- changing information about the book.
_toc.yml
: Table of contents for the textbook. Modify this file for things like:- section and chapter numbering and order;
- adding or removing sections or chapters.
content/
: Content of the textbook. All the notebooks with section and chapter content go here. Modify these files to actually change the content of the sections.
This section details how to maintain the textbook.
Follow these steps the first time you set up a computer to modify and maintain the textbook.
- Create a local copy of this repo by running
git clone https://github.com/prob140/textbook.git
from the command line in whichever folder you want to contain the textbook. - Next, you need to install all the required packages. Either of the commands
pip install -r requirements.txt
orconda install --file requirements.txt
should work. If you have a Windows device, it's preferable to run this in an Anaconda Prompt terminal. This should install the two packagesjupyter-book
andghp-import
, which are used for building and deploying the textbook, respectively, and a bunch of other typical packages (e.g.numpy
,scipy
,matplotlib
, etc.) used by thecontent/
notebooks.
These steps detail the process you should go through every time you update the textbook.
- Pull:
cd
intotextbook/
, your local copy of the textbook repo andgit pull origin master
to collect any updates which may have been pushed to the remote copy by other collaborators. - Update: Make any changes you wish to make. This should (likely) only consist of changes to
_config.yml
,_toc.yml
, and the files incontent/
.- If you added new sections or chapters, update
_toc.yml
as well to reflect your changes.
- If you added new sections or chapters, update
- Build:
cd
into the directory abovetextbook/
(i.e.cd ..
) and runjupyter-book build textbook
. - Check: Open the file
textbook/_build/html/index.html
in your browser to view what the textbook will look like with any changes you've made. Make sure nothing is broken and the changes are as you want them.- See the Troubleshooting section for any issues you may be having.
- Take a look at the Issues for problematic parts of the textbook.
- Deploy:
cd
back intotextbook/
(cd textbook/
) and runghp-import -n -p -f _build/html
(the-n
flag is important, since it adds a.nojekyll
file which allows GitHub to build the website correctly). This will push the_build/html
folder to thegh-pages
branch of the textbook repository, which is configured by GitHub Pages to hold the files for the textbook website. To edit these configurations, from the repository page, go to Settings > Pages. - Push: Stage any changes you made (i.e. using
git add [file]
,git add -u
,git add .
, etc.), commit your changes withgit commit -m "[description]"
(please include a useful description of any changes you made), and push to the master repository withgit push origin master
.
The (Jupyter Book)(https://jupyterbook.org/en/stable/intro.html) website has lots of information about Jupyter Book. Some useful pages are:
- Anatomy of a Jupyter Book
- Table of Contents
- Configuration Reference
- References and Cross-References
- Building
- Deploying
If changes you've made aren't showing up the HTML after building, sometimes deleting _build
and then building again helps. Jupyter Book will usually only re-build the HTML of notebooks that it thinks have been changed by any edits made, and so this sometimes means that some changes will go unnoticed. Deleting the entire folder and rebuilding forces it to build from scratch, which prevents any old files or code from sticking around.
Links to the internet should be done as they are usually done in Markdown. However, to cross-link to other pages of the textbook, there is an internal linking system that should be used instead (since it is robust to file structure changes in /textbook
). This system is described here.
Currently, the Data 140 textbook doesn't use this system for cross-linking, but it should eventually be adapted, as it is more robust to modifications to the file structure.