django-entries
Overview
Basic create-read-update-delete (CRUD) functionality for an Entry
model.
The base template makes use of light css and javascript:
starter.css
stylesheetpylon
0.1.1 for <hstack>
and <vstack>
layoutshtmx
1.6.1 for html-over-the-wire functionality, e.g. infinite scrollinghyperscript
0.9 for client-side reactivitysimplemde
a simple markdown editor
Quickstart
Install in your virtual environment:
.venv> pip3 install django-entries # poetry add django-entries
Include package in main project settings file:
INSTALLED_APPS = [..., "django_entries"]
from django.views.generic import TemplateView
from django.urls import path, include
urlpatterns = [
...,
path("entry/", include("django_entries.urls")),
path(
"", TemplateView.as_view(template_name="home.html")
),
]
Add to database:
.venv> python manage.py migrate # adds the `Entry` model to the database.
.venv> python manage.py createsuperuser # (optional: if fresh project install)
Login to add:
.venv> `python manage.py runserver`
# Visit http://127.0.0.1:8000/entry/entries/list
# Assumes _entry_ as folder in config/urls.py
# The `Add entry` button is only visible to logged in users.
# Can login via admin using the superuser account http://127.0.0.1:8000/admin/
# Visit the list page again at http://127.0.0.1:8000/entry/entries/list to see the `Add entry` button.
Test
.venv> pytest