Build admin-style views with minimal code
Project description
Flexible view system to help you build views quickly.
Fastview slashes development time for modern hybrid frontends - build comprehensive yet customisable CRUD views in a couple of lines, with built-in HTMX support.
Create a view group to manage models - list, read, create, update and delete views
All views are class-based, so they’re quick and easy to customise
Default templates are designed to be customised or replaced to fit your design
Advanced permission system allows fine-grained row-level access control
Built-in support for HTMX (coming soon), inline model formsets and more
Note: this is an alpha release; expect feature and API changes in future versions. Check upgrade notes for instructions when upgrading.
Project site: https://radiac.net/projects/django-fastview/
Documentation: https://django-fastview.readthedocs.io/
Source code: https://github.com/radiac/django-fastview
Requires Python 3.7 or later and Django 2.2 or later
Example
Lets write a wiki where anyone can view, add, edit and delete pages:
# urls.py (for example purposes - normally define the viewgroup in app/views.py)
from fastview.viewgroups import ModelViewGroup
from fastview.permissions import Public
from mywiki.models import Wiki
class WikiViewGroup(ModelViewGroup):
model = Wiki
permission = Public()
urlpatterns = [
url(r'^wiki/', WikiViewGroup().include(namespace="wiki")),
]
This will create a functioning set of list, detail, create, update and delete views under the /wiki/ path on your site.
There are all sorts of things you can do from here:
The views are all based on Django’s generic class-based views, so they’re easy to customise
Easy and flexible permissions to control who can do what
See the Tutorial in the documentation for more details.
Quickstart
Install using pip:
pip install django-fastview
Add to INSTALLED_APPS:
INSTALLED_APPS = [ ... "fastview", ]
Optional: add the default JavaScript and CSS to your templates or frontend build process.
See Getting Started in the documentation for more details.
Advanced example
Build a more complex view group with custom view classes and complex access controls:
# urls.py (for example purposes)
from fastview.viewgroups import ModelViewGroup
from fastview.permissions import Public, Login, Staff, Owner, Django
from myblog.models import Blog
from myblog.views import BlogUpdateView, BlogPublishView
class BlogViewGroup(ModelViewGroup):
model = Blog
# Default permission for views - any views without explicit permissions will
# require that user is logged in
permission = Login()
# Make the list view public by reconfiguring it with a call to View.config()
list_view = fastview.views.generics.ListView.config(
permission=Public(),
)
# Make the detail view public by reconfiguring it with the dict shorthand format
detail_view = dict(
permission=Public(),
)
# Override update with a custom view, and limit access to staff or post owners
update_view = BlogUpdateView.config(
permission=Staff() | Owner("owner"),
)
# Use the Django permission framework to manage who can delete Blog objects
delete_view = dict(
permission=Django("delete"),
)
# Add a publish view where only staff can access, but only if it's not their own
publish_view = BlogPublishView.config(
permission=Staff() & ~Owner("owner"),
)
urlpatterns = [
url(r'^blog/', BlogViewGroup().include(namespace="blog")),
]
You may then want to create a custom templates at templates/myblog/blog/list.html and templates/myblog/blog/detail.html to change the way blog posts are rendered.
For more details see the main documentation.
More examples
See Examples in the documentation for more details on these two examples, as well as how you can use fastview to:
configure and customise the views
use permissions to control access to individual database objects
add inline models to your forms
and more
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
Built Distribution
File details
Details for the file django-fastview-0.1.0.tar.gz
.
File metadata
- Download URL: django-fastview-0.1.0.tar.gz
- Upload date:
- Size: 49.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 553bfecddebe4406a2a1b4db797e848d15da664df9af0be53ae6298d619b9c27 |
|
MD5 | 11e47dd5d899b0508d37a82ef425de26 |
|
BLAKE2b-256 | f35ca2bbabde38f7b4a2949830f18fac2d3ebdad7880a65f1dbb0f679d7e56a2 |
File details
Details for the file django_fastview-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: django_fastview-0.1.0-py3-none-any.whl
- Upload date:
- Size: 52.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9cbaf2e1903f3e85bbda9c1c0c08e6f2c3880eaf79ff3d1299f91144bd380d09 |
|
MD5 | 6d07d5d6673d0c9cbc05cef67ef2679d |
|
BLAKE2b-256 | 165a19c761c806f2a51c38f862059632fc3a279eca11afa3c52ca9006bd22810 |