Efficient id manager for Plotly Dash.
Project description
Dash ID Manager
A Python library for efficient and scalable ID management in Plotly Dash applications using dataclasses. Simplify and standardize the way you handle component IDs, enhancing maintainability, reducing errors, and improving developer experience.
README Language
Features
- Hierarchical ID Grouping: Use dataclasses to group IDs hierarchically, reflecting the structure of your Dash application.
- Automatic Prefix Insertion: Automatically inserts prefixes based on the class hierarchy, indicating the page and component hierarchy.
- Centralized ID Management: Define all IDs in a single location (e.g.,
__init__.py
), making ID management consistent and maintainable across the entire project. - Enhanced Error Reporting: When errors occur, it's clear which page and component the ID belongs to, facilitating easier debugging.
- Improved Editor Support: Leverage editor indexing and autocomplete features for faster development and reduced type errors.
- Declarative ID Definitions: Manage IDs declaratively using dataclasses, reducing boilerplate and improving readability.
- Automatic Kebab-Case Conversion: Automatically converts field names to kebab-case for consistent ID formatting without additional code.
- Immutable and Type-Safe: Utilizes frozen dataclasses to ensure ID integrity and prevent accidental modifications.
Installation
You can install the library via pip:
pip install dash-id-manager
Usage
Here's an advanced example demonstrating how to efficiently manage IDs using Dash ID Manager in your Dash application:
# pages/__init__.py
from dash_id_manager import BaseIDs
from dataclasses import dataclass
from typing import ClassVar
@dataclass(frozen=True)
class DashboardIDs(BaseIDs):
_prefix: ClassVar[str] = "dashboard"
@dataclass(frozen=True)
class DashboardHeaderIDs(DashboardIDs):
_prefix: ClassVar[str] = "header"
title: str
logout_button: str
@dataclass(frozen=True)
class DashboardSidebarIDs(DashboardIDs):
_prefix: ClassVar[str] = "sidebar"
navigation_menu: str
profile_section: str
@dataclass(frozen=True)
class DashboardContentIDs(DashboardIDs):
_prefix: ClassVar[str] = "content"
graph: str
data_table: str
# Initialize all ID groups
header_ids = DashboardHeaderIDs()
sidebar_ids = DashboardSidebarIDs()
content_ids = DashboardContentIDs()
# app.py
import dash
from dash import html, dcc
from pages import header_ids, sidebar_ids, content_ids
app = dash.Dash(__name__)
app.layout = html.Div([
html.Header([
html.H1(id=header_ids.title), # id = "dashboard-header-title"
html.Button("Logout", id=header_ids.logout_button) # id = "dashboard-header-logout-button"
], id=header_ids._prefix), # id = "dashboard-header"
html.Aside([
html.Nav(id=sidebar_ids.navigation_menu), # id = "dashboard-sidebar-navigation-menu"
html.Div(id=sidebar_ids.profile_section) # id = "dashboard-sidebar-profile-section"
], id=sidebar_ids._prefix), # id = "dashboard-sidebar"
html.Main([
dcc.Graph(id=content_ids.graph), # id = "dashboard-content-graph"
html.Table(id=content_ids.data_table) # id = "dashboard-content-data-table"
], id=content_ids._prefix) # id = "dashboard-content"
])
if __name__ == '__main__':
app.run_server(debug=True)
Demonstrated Advantages
- Hierarchical Grouping:
DashboardIDs
groups all related component IDs, reflecting the structure of the page. - Automatic Prefixing: Each subclass (e.g.,
DashboardHeaderIDs
,DashboardSidebarIDs
) automatically inherits the parent prefix, generating IDs likedashboard-header-title
. - Centralized Management: All IDs are defined in
__init__.py
, making them easily accessible and modifiable. Of course, they can be split into other files as well. - Improved Error Reporting: Structured naming ensures that when ID-related errors occur, the affected pages or components are clearly identified.
- Editor Support: IDEs can autocomplete entries like
dashboard_ids.header.title
, reducing the possibility of typos. - Declarative Definitions: Using data classes to declaratively define IDs makes the code cleaner and easier to maintain.
- Automatic Kebab-Case Conversion: Field names like
logout_button
are automatically converted tologout-button
, ensuring consistent ID formatting. - Immutable IDs: Using frozen data classes maintains the integrity of IDs by preventing runtime changes.
License
This project is licensed under the MIT License. See the LICENSE file for details.
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 Distribution
dash_id_manager-1.0.6.tar.gz
(4.8 kB
view details)
Built Distribution
File details
Details for the file dash_id_manager-1.0.6.tar.gz
.
File metadata
- Download URL: dash_id_manager-1.0.6.tar.gz
- Upload date:
- Size: 4.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3e84ef92f29fe214508363d25181ca4a3c4915495d27c1cc1eb3ce5f5b097c0d |
|
MD5 | d21dc203f95986052aa7a27dc17bc9a6 |
|
BLAKE2b-256 | 0cb7c10dedffd402b9bd8b50d9cef20ac77a6e0328ca8128ed25dca02e519a42 |
File details
Details for the file dash_id_manager-1.0.6-py3-none-any.whl
.
File metadata
- Download URL: dash_id_manager-1.0.6-py3-none-any.whl
- Upload date:
- Size: 4.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c634a6a376e56215d5ed05f7b238b80928b585464a0559fc9e2e7bb5dd99dee |
|
MD5 | 8d700e93f676c322247dcbb41018b754 |
|
BLAKE2b-256 | 54bf9a1afd52af4721f0fd01c82cdad6fb5e6a1940b5dc2b29c9d6a8bb76a665 |