A reusable blog app powered by Python, Django, DRF, Wagtail CMS, TailwindCSS and DaisyUI.
Project description
django-w-blog
Overview
A reusable, production-ready blog application built with Python, Django, Django REST Framework, and Wagtail CMS, styled with Tailwind CSS and daisyUI. It ships with sane defaults, modern theming, and clean APIs to help you launch quickly and scale confidently.
Demo
Key features
- Full CMS: Wagtail-powered editorial experience with pages, media, search, and governance.
- Modern UI: Tailwind CSS for utility-first styling and responsive layouts.
- Theming: All daisyUI themes supported, plus the ability to define custom themes.
- API ready: Optional REST API endpoints for content delivery and integrations.
- CI/CD: GitHub Actions pipelines for consistent, automated testing and deployment.
- Dependencies: Managed with Poetry for reproducibility and clarity.
- Formatting: Black for automatic, consistent code formatting.
- Linting: Ruff for fast, comprehensive linting.
- Testing: Django test runner for unit and integration tests.
- Configs included:
.gitignore,pyproject.toml, and other boilerplate to streamline setup.
Installation
pip install django-w-blog
Configuration
Add installed apps
# project/settings.py
INSTALLED_APPS = [
"blog",
"blog.api", # Optional if you don't need the API
"blog.apps.articles",
"blog.apps.categories",
"blog.apps.home", # Optional if your project includes a Home model ('home.Home')
"blog.apps.indexes",
"blog.apps.tags",
"blog.cms",
"blog.ui",
# Dependencies
"rest_wind", # Optional if you don't need the API
"rest_framework", # Optional if you don't need the 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
# In your project root
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("blog.ui.urls")),
path("api/", include("blog.api.urls")), # Optional if you don't need the API
path("api/", include("rest_framework.urls")), # Optional if you don't need the API
# ...
path("documents/", include(wagtaildocs_urls)),
path("dashboard/", include(wagtailadmin_urls)),
path("", include(wagtail_urls)), # Keep this as the last pattern
]
Theming and templates
Each template in django-w-blog extends blog/base.html. Start by creating this base template in your project and customize it to match your brand.
Create the blog template directory
mkdir -p your_app/templates/blog
Create the base template
touch your_app/templates/blog/base.html
You can extend blog/base.html in your own templates or override any provided template for full control.
Available blocks and context
-
blog/base.html- Blocks:
- theme: Default daisyUI theme
- toggle_theme: Secondary daisyUI theme
- head: HTML head content
- title: Page title
- styles: CSS styles links
- navbar: Navigation bar
- branding: Branding in navbar
- navbar_center: Centered navbar links
- navbar_end: Right-aligned navbar links
- content: Main content
- footer: Page footer
- drawer_branding: Sidebar branding
- drawer_content: Sidebar content
- Context:
- home: Site root page
- Blocks:
-
blog/index.html- Blocks: All blocks from
blog/base.html - Context:
- index: Blog index page
- articles: Latest blog articles
- Blocks: All blocks from
-
blog/category.html- Blocks: All blocks from
blog/base.html - Context:
- category: Category instance
- Blocks: All blocks from
-
blog/article.html- Blocks: All blocks from
blog/base.html - Context:
- article: Article instance
- Blocks: All blocks from
-
blog/search.html- Blocks: All blocks from
blog/base.html - Context:
- search_results: Results as a
PageQuerySet
- search_results: Results as a
- Blocks: All blocks from
Contributing
We welcome contributions. 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 start a thread in GitHub Discussions.
License
This project is available under the MIT License. See the LICENSE file for details.
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 django_w_blog-0.2.1.tar.gz.
File metadata
- Download URL: django_w_blog-0.2.1.tar.gz
- Upload date:
- Size: 58.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
43edabf5cf2bb14f76110efe04ef2c255c3612cadad756ae0ee273ce22b36af1
|
|
| MD5 |
979968694a9778e254fdc921243e7fb8
|
|
| BLAKE2b-256 |
ab183eb75cc8ccc05a8aacde01af5af03b0db289cd66c756f32257656688f8ef
|
File details
Details for the file django_w_blog-0.2.1-py3-none-any.whl.
File metadata
- Download URL: django_w_blog-0.2.1-py3-none-any.whl
- Upload date:
- Size: 87.5 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0521bb851b92a5dcb9669bcb2fe6d53411836dcb913cf6ce9a1261f63cee4619
|
|
| MD5 |
501f0afeaf8aeddf4e2df6375a2ad0ca
|
|
| BLAKE2b-256 |
c2ff29efc663419ede4e1646358288ed0ab5b64e860263745b340a0792c6ab81
|