Skip to main content

Simple and lightweight data managment framework powered by FastAPI and Vue3 Vuetify all-in-one. Some call it heavenly in its brilliance.

Project description

Brilliance Admin

PyPI CI

Simple and lightweight data management framework powered by FastAPI and Vue3 Vuetify all-in-one.
Integrated with SQLAlchemy. Inspaired by Django Admin and DRF.
Some call it heavenly in its brilliance.

Live Demo | Demo Sources | Documentation

Preview

Brilliance Admin provides

A quick way to create a data management interface using:

  • Admin page - endpoint with a prebuilt SPA frontend Vue3 + Vuetify
    This endpoint can be added to any ASGI compatable backend. For existing project or standalone admin app.
  • API to fetch the UI JSON schema
  • API methods for that UI to work with (to read and modify data)

Screenshots

Key ideas

  • API Oriented
    Data generation/updating API separated from rendering fontend with zero hardcode, this makes it possible to have a single frontend with multiple backend implementations in different languages and makes test coverage easier.
  • Rich visualization
    Providing rich and convenient ways to display and manage data (tables, charts, etc) from any data source.
  • UI JSON Schema
    Represents the data describing the structure of entire admin panel UI.
    You only need to specify what should be rendered. The frontend will display it and automatically request data from the backend for rendering or updates.
  • ORM
    Automatic generation from ORM for schema UI frontend and backend methods for CRUD operations.
  • Minimal boilerplate
    Focused on simplified, but rich configuration.

Features

  • Tables with full CRUD support, including filtering, sorting, and pagination.
  • Ability to define custom table actions with forms, response messages, and file downloads.
  • Graphs via ChartJS
  • Localization support
  • Adapted for different screen sizes and mobile devices
  • Auth via any account data source

Integrations:

  • SQLAlchemy - schema autogeneration for tables + CRUD operations + authorization

Planned:

  • Dashboard features
  • Role-based access permissions system via interface
  • Backend interface for storing and viewing action history in the admin interface
  • Nested data support for creation and detail views (inline editing), nested CRUD workflows
  • Django ORM integration
  • Support for Oauth providers

Installation:

pip install brilliance-admin

Usage example

You need to generate AdminSchema instance:

from brilliance_admin import schema


class CategoryExample(schema.CategoryTable):
    "Implementation of get_list and retrieve; update and create are optional"


admin_schema = schema.AdminSchema(
    title='Admin Panel',
    auth=YourAdminAuthentication(),
    categories=[
        schema.Category(
            slug='example',
            categories=[
                CategoryExample(),
            ]
        ),
    ],
)

admin_app = admin_schema.generate_app()

# Your FastAPI app (Any ASGI framework can be used)
app = FastAPI()
app.mount('/admin', admin_app)

For more details, check out our how-to-start documentation

Comparison of Similar Projects

The project closest in concept is React Admin.
It is an SPA frontend that store the schema UI inside and works with separate API backend providers.

The key difference of Brilliance Admin is that its all-in-one.
It is more focused on rapid setup for data management, without the need to work with frontend configuration, while it still available.

Comparison of Similar Python Projects

Criterion Brilliance Admin Django Admin FastAPI Admin Starlette Admin SQLAdmin
Base framework FastAPI Django FastAPI Starlette FastAPI
ASGI compatible Yes Partial Yes Yes Yes
Rendering model Prebuilt Vue 3 + Vuetify SPA + Jinja2 Server-side Django templates Server-side Jinja2 templates + Tabler UI Server-side Jinja2 templates + Tabler UI Server-side Jinja2 templates + Bootstrap
Frontend architecture Separate frontend (SPA) Classic server-rendered UI Server-rendered UI with JS interactivity Server-rendered UI with JS interactivity Server-rendered UI
Data source Any source + SQLAlchemy Django ORM Tortoise ORM Any source + SQLAlchemy, MongoDB SQLAlchemy
Multiple databases per model Yes Database routers No (global engine) Yes (session per ModelView) No (single engine per Admin)
Schema generation User-defined format From Django models From ORM models User-defined format From SQLAlchemy models
Async support Yes No Yes Yes Yes
API-first approach Yes No Partially Partially No
Built-in Localization Yes Yes No No No

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

brilliance_admin-0.44.19.tar.gz (3.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

brilliance_admin-0.44.19-py3-none-any.whl (3.7 MB view details)

Uploaded Python 3

File details

Details for the file brilliance_admin-0.44.19.tar.gz.

File metadata

  • Download URL: brilliance_admin-0.44.19.tar.gz
  • Upload date:
  • Size: 3.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for brilliance_admin-0.44.19.tar.gz
Algorithm Hash digest
SHA256 cd6d31ec57a60a29937e03f611794df768295c1b870696308bc038ab87e4e66b
MD5 3547d230abfe858dbd837973a94e4ba7
BLAKE2b-256 48b3a00cc8a5fb0fbefd870dd49066e93e875cb8ef8b3dbb59c4e25bfd5a7907

See more details on using hashes here.

File details

Details for the file brilliance_admin-0.44.19-py3-none-any.whl.

File metadata

File hashes

Hashes for brilliance_admin-0.44.19-py3-none-any.whl
Algorithm Hash digest
SHA256 6f2e308d8e6a7f26d5d0ade04f38e0d520f57a10c4efab46881fdeb8d686e46c
MD5 a3094bd174527e444294d7b043ba7742
BLAKE2b-256 e1a809a2bdd3e3d335392eb0e6c6692507f079c2a17acd12a857fdbc769ab782

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page