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:
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.
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.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | bf6a4d4ba2ea0ec5329206fd03f43d9e84f9a10f6fb1abd8f2abae0aaa1b5d49 |
|
MD5 | 819684c6c6a11fc3153e57a9c5d9c63f |
|
BLAKE2b-256 | 9a2a6348d03c3304ed7db1a4587dff54f9bc991bac3e2355da41ac53f9d57891 |