MolCrafts theme extension for Zensical documentation sites.
Project description
MolCrafts Zensical Theme
Shared Zensical theme extension for MolCrafts documentation sites.
Install
pip install molcrafts-zensical-theme
Consuming sites should pin the theme in the dependency group that builds their docs so builds stay reproducible:
[dependency-groups]
docs = [
"zensical>=0.0.45",
"molcrafts-zensical-theme>=0.1.0",
]
For theme development, install the checkout in editable mode instead
(pip install -e .).
Use
Add the theme to a Zensical project:
[project]
site_name = "MolCrafts Project"
site_url = "https://example.molcrafts.org/"
[project.theme]
name = "molcrafts"
[project.extra.molcrafts]
product = "molpy"
accent = "#0284c7"
accent_soft = "rgba(2, 132, 199, 0.14)"
All three values are optional. product tags the page
(html[data-molcrafts-product="…"]) so site or theme CSS can target one
product. accent sets the product accent (links, hovers, hero eyebrows);
accent_soft is its translucent companion and, when omitted, is derived from
accent via color-mix. Sites that set none of these fall back to the brand
forest/sand accent. The theme ships no per-product color map — each product
declares its own accent in its zensical.toml; the colors the old map used to
assign are kept for reference in a comment at the top of
assets/stylesheets/molcrafts.css.
The theme defaults to Zensical's modern variant, MolCrafts brand colors from
moko.svg, Inter text, JetBrains Mono code, light/dark palettes, navigation
tabs, section indexes, instant navigation, code-copy controls, search
highlighting and suggestions, and TOC following. Consuming sites should not
re-list these features/palette in their own zensical.toml — the theme
already supplies them, and an inline list only risks drifting from the defaults.
Home page
The theme ships a manual-style landing layout that a stock Zensical site does not have. It has two parts: a hero driven by page front-matter, and a set of manual-home components you compose in Markdown/HTML in the page body.
Hero (front-matter)
Set a hero mapping in the home page's front-matter; the theme's main.html
renders it above the content. Every field is optional except that a hero only
renders when the hero key is present. The eyebrow above the title is always
"Manual" — it is not configurable.
---
title: molpack
hide: [navigation, toc]
hero:
title: molpack # defaults to site_name if omitted
description: One or two sentences of positioning.
actions: # buttons; style "primary" fills, else outline
- { label: Get started, href: getting_started/, style: primary }
- { label: Guide, href: concepts/ }
install: # right-hand card with a copy button;
label: Install # plain string works too, shorthand
command: pip install molpack # for { command: … }
badges: # badge row under the install card
- img: https://img.shields.io/pypi/v/molpack
href: https://pypi.org/project/molpack/
alt: PyPI version
---
Manual-home components (body)
Wrap the body in .molcrafts-manual-home and compose these building blocks (all
are plain HTML with markdown where inner Markdown is wanted):
| Class | Purpose |
|---|---|
molcrafts-manual-section |
A titled row; pair with molcrafts-manual-section__header + molcrafts-manual-eyebrow |
molcrafts-manual-index |
Numbered "find the right page" entry list (<a><span>01</span><strong>…</strong><em>…</em></a>) |
molcrafts-manual-grid |
Responsive card grid; add --cols-2 or --cols-3 (see templates below) |
molcrafts-manual-list |
Vertical row list of label/description pairs (lighter than manual-index) |
molcrafts-workflow-list |
Side-labelled <article>s, each with a molcrafts-workflow-list__meta tag and a code block |
molcrafts-feature-matrix |
Two-column <dl> of capability <dt>/<dd> pairs |
molcrafts-doc-map |
Grid of <section><h3>…</h3><p>…</p></section> linking to nav areas |
molcrafts-sr-only |
Visually-hidden <h1> so the page still has a heading for a11y/search |
See examples/basic/docs/index.md for a complete, copyable example, and the
molpy / molpack docs/index.md for production use.
Section templates
A section is built from two orthogonal, opt-in choices so a sub-manual picks a layout instead of relying on grid auto-placement. Pick a frame (how the titled block splits its label from its content) and drop a content template (how the items inside are arranged) into it.
Frames — modifiers on molcrafts-manual-section:
| Modifier | Layout |
|---|---|
| (none) | Two columns: a sticky label column beside the content |
--compact |
Two columns with a static label; a trailing paragraph stacks under the label while the content (e.g. a code block) spans the second column |
--stack |
Single column: eyebrow + title on top, content full width below — use to host wide content or a three-column grid |
Content templates — drop one into a frame's body (or straight into
molcrafts-manual-home):
| Template | Arrangement |
|---|---|
molcrafts-manual-grid molcrafts-manual-grid--cols-2 |
Two-column card grid → one column on narrow screens |
molcrafts-manual-grid molcrafts-manual-grid--cols-3 |
Three-column card grid → two, then one |
molcrafts-manual-list |
Vertical list of rows |
molcrafts-manual-index |
Numbered entry list |
Each card / row is an <a> (link, with accent hover) or a <div>, holding a
<strong> label and an <em> or <p> description. A three-column grid needs
the room a --stack frame gives it:
<section class="molcrafts-manual-section molcrafts-manual-section--stack" markdown>
<div class="molcrafts-manual-section__header" markdown>
<span class="molcrafts-manual-eyebrow">Capabilities</span>
## What molpy gives you
</div>
<div class="molcrafts-manual-grid molcrafts-manual-grid--cols-3">
<a href="build/"><strong>Build</strong><em>Assemble systems from parts.</em></a>
<a href="type/"><strong>Type</strong><em>Assign force-field parameters.</em></a>
<a href="export/"><strong>Export</strong><em>Write LAMMPS, GROMACS, PDB.</em></a>
</div>
</section>
Local Example
zensical build -f examples/basic/zensical.toml
zensical serve -f examples/basic/zensical.toml
The usage surface is Zensical-native: configure sites with zensical.toml.
Zensical 0.0.45 still discovers packaged themes through the historical
mkdocs.themes entry point and reads theme-package defaults from
mkdocs_theme.yml; this package uses those hooks only for Zensical theme
discovery, not for mkdocs.yml configuration.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file molcrafts_zensical_theme-0.1.1.tar.gz.
File metadata
- Download URL: molcrafts_zensical_theme-0.1.1.tar.gz
- Upload date:
- Size: 24.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
322ea6b09fa7c63369df426f09f5fb3dbffb8beeead5b0903efcd5d205cf138b
|
|
| MD5 |
6732e0ec7ffc4916bf5fd32732c72f16
|
|
| BLAKE2b-256 |
afd8567ced4531386a516b995b16ec63c88fc60966c8b94c0d480f4b28848c9c
|
Provenance
The following attestation bundles were made for molcrafts_zensical_theme-0.1.1.tar.gz:
Publisher:
release.yml on MolCrafts/molcrafts-zensical-theme
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
molcrafts_zensical_theme-0.1.1.tar.gz -
Subject digest:
322ea6b09fa7c63369df426f09f5fb3dbffb8beeead5b0903efcd5d205cf138b - Sigstore transparency entry: 2068783124
- Sigstore integration time:
-
Permalink:
MolCrafts/molcrafts-zensical-theme@09f783d7119126c9c63c6b9bbb0b865dfa7411fa -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/MolCrafts
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@09f783d7119126c9c63c6b9bbb0b865dfa7411fa -
Trigger Event:
push
-
Statement type:
File details
Details for the file molcrafts_zensical_theme-0.1.1-py3-none-any.whl.
File metadata
- Download URL: molcrafts_zensical_theme-0.1.1-py3-none-any.whl
- Upload date:
- Size: 22.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
80972e20f6e11f34b3fe25892fe19a9dce8bc11cbde9851424de74ac08cabedf
|
|
| MD5 |
60b7c073c47482f61a17585fd6aaf519
|
|
| BLAKE2b-256 |
d324a111492383ffc21b82211074dc1d0e15179e0864d527b9481b5339665d3b
|
Provenance
The following attestation bundles were made for molcrafts_zensical_theme-0.1.1-py3-none-any.whl:
Publisher:
release.yml on MolCrafts/molcrafts-zensical-theme
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
molcrafts_zensical_theme-0.1.1-py3-none-any.whl -
Subject digest:
80972e20f6e11f34b3fe25892fe19a9dce8bc11cbde9851424de74ac08cabedf - Sigstore transparency entry: 2068783243
- Sigstore integration time:
-
Permalink:
MolCrafts/molcrafts-zensical-theme@09f783d7119126c9c63c6b9bbb0b865dfa7411fa -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/MolCrafts
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@09f783d7119126c9c63c6b9bbb0b865dfa7411fa -
Trigger Event:
push
-
Statement type: