Skip to main content

a reusable, production-ready documentation application built with Python, Django, Django REST Framework, and Wagtail CMS, styled with Tailwind CSS and daisyUI. It comes with sensible defaults, modern theming, and clean APIs—helping you launch structured, searchable documentation quickly and scale it with confidence.

Project description

django-w-docs

CI CD Code Style: Black Code Linting: Ruff Docker Image Docker Publish PyPI - Version PyPI - Python Version PyPI - Downloads PyPI - License

Overview

django-w-docs is a reusable, production-ready documentation application built with Python, Django, Django REST Framework, and Wagtail CMS, styled with Tailwind CSS and daisyUI. It comes with sensible defaults, modern theming, and clean APIs—helping you launch structured, searchable documentation quickly and scale it with confidence.


Demo

Demo


Key features

  • Full CMS: Wagtail-powered editorial interface with pages, media, search, and governance.
  • Modern UI: Utility-first styling with Tailwind CSS for responsive, accessible layouts.
  • Theming: All daisyUI themes included, with support for custom themes.
  • API ready: Optional REST API endpoints for headless delivery and integrations.
  • CI/CD: GitHub Actions pipelines for automated testing, linting, and deployment.
  • Dependencies: Managed with Poetry for reproducibility and clarity.
  • Formatting: Black for consistent, automatic code formatting.
  • Linting: Ruff for fast, comprehensive linting.
  • Testing: Django test runner for unit and integration tests.
  • Starter configs: .gitignore, pyproject.toml, and other boilerplate included.

Use cases

  • Product docs & API reference: Guides, FAQs, and endpoint documentation with search and tags.
  • Knowledge base: Self‑serve help center to reduce support load.
  • Internal handbook: Onboarding, SOPs, and runbooks with role‑based access.
  • Release notes & policies: Publish updates, policies, and compliance docs.
  • Multilingual content: Maintain parity across languages with Wagtail i18n.
  • In‑product help: Surface contextual docs via the REST API.

Installation

pip install django-w-docs

Configuration

Add installed apps

# project/settings.py

INSTALLED_APPS = [
    "docs",
    "docs.api",              # Optional: REST API
    "docs.apps.home",        # Optional: if your project includes a Home model ('home.Home')
    "docs.apps.indexes",
    "docs.apps.pages",
    "docs.apps.sections",
    "docs.apps.tags",
    "docs.cms",
    "docs.ui",

    # Dependencies
    "rest_wind",             # Optional: REST API
    "rest_framework",        # Optional: REST API
    "wagtail_blocks",
    "wagtail.contrib.search_promotions",
    "wagtail.contrib.forms",
    "wagtail.contrib.redirects",
    "wagtail.embeds",
    "wagtail.sites",
    "wagtail.users",
    "wagtail.snippets",
    "wagtail.documents",
    "wagtail.images",
    "wagtail.search",
    "wagtail.admin",
    "wagtail",
    "modelcluster",
    "taggit",
    # ...
]

Run migrations

python manage.py migrate

Update URL configuration

# project/urls.py

from django.urls import include, path
from wagtail import urls as wagtail_urls
from wagtail.admin import urls as wagtailadmin_urls
from wagtail.documents import urls as wagtaildocs_urls

urlpatterns = [
    path("", include("docs.ui.urls")),
    path("api/", include("docs.api.urls")),           # Optional: REST API
    path("api/", include("rest_framework.urls")),     # Optional: REST API
    # ...
    path("documents/", include(wagtaildocs_urls)),
    path("dashboard/", include(wagtailadmin_urls)),
    path("", include(wagtail_urls)),                  # Keep this last
]

Theming and templates

All templates in django-w-docs extend docs/base.html. Create and customize this base template to match your brand.

Create the template directory

mkdir -p your_app/templates/docs

Create the base template

touch your_app/templates/docs/base.html

You can extend docs/base.html in your own templates or override any provided template for full control.

Available blocks and context

  • docs/base.html

    • Blocks: theme, toggle_theme, head, title, styles, navbar, branding, navbar_center, navbar_end, content, footer, drawer_branding, drawer_content
    • Context: home (site root page)
  • docs/index.html

    • Blocks: All from docs/base.html
    • Context: index (docs index page)
  • docs/section.html

    • Blocks: All from docs/base.html
    • Context: section (DocsSection instance)
  • docs/page.html

    • Blocks: All from docs/base.html
    • Context: page (DocsPage instance)
  • docs/search.html

    • Blocks: All from docs/base.html
    • Context: search_results (PageQuerySet results)

Contributing

We welcome contributions from the community. Please review the CONTRIBUTING guide for setup, coding standards, and workflow. Opening an issue before major changes helps align on scope and direction.


Support

For questions, bug reports, or feature requests, open an issue or join the conversation in GitHub Discussions.


License

This project is licensed under the MIT License. See the LICENSE file for details.

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

django_w_docs-1.0.9.tar.gz (81.1 kB view details)

Uploaded Source

Built Distribution

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

django_w_docs-1.0.9-py3-none-any.whl (116.3 kB view details)

Uploaded Python 3

File details

Details for the file django_w_docs-1.0.9.tar.gz.

File metadata

  • Download URL: django_w_docs-1.0.9.tar.gz
  • Upload date:
  • Size: 81.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.3 Linux/6.11.0-1018-azure

File hashes

Hashes for django_w_docs-1.0.9.tar.gz
Algorithm Hash digest
SHA256 f308e3e7ace00ad03c3fd184f1023609167931ab8f54b13a4ec20b35b5c0613d
MD5 73d0bc16200f25efd96a60e80b639b02
BLAKE2b-256 5e83ba1490d9292dc6e0c8cea95977bd2252d1f3f03cd4aa1d4b9258a30d728b

See more details on using hashes here.

File details

Details for the file django_w_docs-1.0.9-py3-none-any.whl.

File metadata

  • Download URL: django_w_docs-1.0.9-py3-none-any.whl
  • Upload date:
  • Size: 116.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.12.3 Linux/6.11.0-1018-azure

File hashes

Hashes for django_w_docs-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 7219672179dc17900259bad43ae68fdc161f37bd5f22c528504497374197252e
MD5 34ab22a3af978689eec326b5c6e6cfd5
BLAKE2b-256 03feb7d6627af0662ff4cfe9096677bd8ee3af970df30bf58708141280480693

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