Skip to main content

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


Download files

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

Source Distribution

molcrafts_zensical_theme-0.1.1.tar.gz (24.6 kB view details)

Uploaded Source

Built Distribution

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

molcrafts_zensical_theme-0.1.1-py3-none-any.whl (22.2 kB view details)

Uploaded Python 3

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

Hashes for molcrafts_zensical_theme-0.1.1.tar.gz
Algorithm Hash digest
SHA256 322ea6b09fa7c63369df426f09f5fb3dbffb8beeead5b0903efcd5d205cf138b
MD5 6732e0ec7ffc4916bf5fd32732c72f16
BLAKE2b-256 afd8567ced4531386a516b995b16ec63c88fc60966c8b94c0d480f4b28848c9c

See more details on using hashes here.

Provenance

The following attestation bundles were made for molcrafts_zensical_theme-0.1.1.tar.gz:

Publisher: release.yml on MolCrafts/molcrafts-zensical-theme

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file molcrafts_zensical_theme-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for molcrafts_zensical_theme-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 80972e20f6e11f34b3fe25892fe19a9dce8bc11cbde9851424de74ac08cabedf
MD5 60b7c073c47482f61a17585fd6aaf519
BLAKE2b-256 d324a111492383ffc21b82211074dc1d0e15179e0864d527b9481b5339665d3b

See more details on using hashes here.

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

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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