Skip to main content

Ulwazi theme for Sphinx documentation projects

Project description

Ulwazi Sphinx theme

Ulwazi, Xhosa for information, is a work-in-progress Sphinx theme based on Vanilla design.

Demo website

Layout and functionality is derived from sphinx-basic-ng, developed by praduimsg and Alabaster.

The theme will default to a generic Vanilla Framework style but will have options for the specific Canonical theming to support the org's documentation needs.

Installing Node Modules

Make sure you have npm and Yarn installed:

sudo apt install npm
sudo npm install -g corepack

If you do not have the node_modules directory (for example, after cloning the repository for the first time), install the JavaScript dependencies:

yarn install

Testing

A Makefile includes some basic functionality to build the theme and then build and run the test content with the theme.

To build the sample documentation using the theme, run:

make run

This command set ups a virtual environment, installs dependencies, builds theme, then documentation in this repo, and serves the result via local web server.

The resulted environment tracks changes in sample content and rebuilds the local website automatically. However, changes to the theme might require a full rebuild of the theme package:

make rebuild

This command runs make clean to delete files built earlier, and then make run again.

If you change dependencies (for example, add a new Sphinx extension to the docs/requirements.txt file), you will need to re-build the virtual environment entirely. That can be done by manually deleting the .venv folder or with the make fclean command.

Contributing

The theme files are located in the ulwazi folder:

  • __init__.py -- initialization script for the theme.
  • navigation.py -- modifies the global TOC navigation tree
  • theme/ulwazi/ -- contains the theme files
    • theme.toml -- theme configuration file
    • static -- static content to be used by the theme without processing
    • other files -- HTML templates for Sphinx using Jinja templating engine

If you want to modify HTML code of a page generated by Sphinx before the theme gets applied, see the _html_page_context function definition in the initialization script.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ulwazi-0.4.tar.gz (184.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ulwazi-0.4-py3-none-any.whl (203.3 kB view details)

Uploaded Python 3

File details

Details for the file ulwazi-0.4.tar.gz.

File metadata

  • Download URL: ulwazi-0.4.tar.gz
  • Upload date:
  • Size: 184.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for ulwazi-0.4.tar.gz
Algorithm Hash digest
SHA256 7b96163c2313c2057ccf4fbbb99eb2b44b0079ffefa12f4dd52378ae9418f0f3
MD5 00e1b43e72368716c08b740ab710ac96
BLAKE2b-256 f0262dffe9f3c3896600360d4b2e35b423fa81abcca69b9784c271cc5c6d5f40

See more details on using hashes here.

File details

Details for the file ulwazi-0.4-py3-none-any.whl.

File metadata

  • Download URL: ulwazi-0.4-py3-none-any.whl
  • Upload date:
  • Size: 203.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for ulwazi-0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 61b02fe021eb066f927747810553b3d40a5c245f9037c4abe52e2951737bdf6a
MD5 e9a1bd4aed6f727e5b160ea7319aa140
BLAKE2b-256 ad81d45f00a33a4735ef8c0a5e0c041ac7dfbac5d92a15012547c06345701743

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page