A simple and powerful admin for Piccolo models, using ASGI.
Project description
Piccolo Admin
piccolo_admin provides a simple admin interface on top of Piccolo models.
Demo
To run a demo, using Python 3.7 or above:
pip install piccolo_admin
admin_demo
And then just launch localhost:8000
in your browser.
To see what happens behind the scenes, see piccolo_admin/example.py
.
In a few lines of code we are able to:
- Define our models
- Setup a database
- Create a REST API
- Setup a web server and admin interface
ASGI
Since the admin is an ASGI app, you can either run it standalone like in the demo, or integrate it with a larger ASGI app.
For example, using Starlette routes:
from piccolo_admin.endpoints import AdminRouter
from starlette.routing import Router, Route
import uvicorn
from my_project.tables import Movie, User
from my_project.endpoints import Hello
admin = AdminRouter(Movie, auth_table=User)
router = Router([
Route(path="/", endpoint=Hello),
Mount(path="/admin/", app=admin),
])
if __name__ == '__main__':
uvicorn.run(router)
Contributing
The backend is just vanilla Python.
The front end is built using Vue.js. To make modifications, clone the repo, and cd into the admin_ui
directory.
Install the npm dependencies:
npm install
And then you can launch the admin as follows:
npm run serve
It will auto refresh the UI as you make changes to the source files.
The UI needs an API to interact with - the easiest way to do this is to use the demo app.
admin_demo
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 Distributions
Built Distribution
Hashes for piccolo_admin-0.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e2f13f089a00bbec09d0cef6afef5b451222d7b0363fee571bdc061e726c681c |
|
MD5 | 5830a07c73b427d60b750a6788b16d75 |
|
BLAKE2b-256 | 7bfbb8b4c9143eace4eb3eb7abd1a5f0c0618f9a270749d59edb5d29c16b5e26 |