A customizable LLM chat UI framework built on Plotly Dash
Project description
Dash AI Chat
Stop building chat UIs from scratch every time. Get a fully-functional AI chat interface with 3 lines of code, then infinitely customize and extend without starting over every time.
✨ Key Features
- 🚀 Quick Setup: Get a chat UI running in 3 lines of code
- 🎨 Highly Customizable: Override any component to match your design
- 🔌 Multi-Provider Support: OpenAI, Anthropic, Google Gemini, or any other provider
- 💾 Persistent Storage: Chat history saved automatically
- 📱 Responsive Design: Works beautifully on desktop and mobile
- 🎯 Production Ready: Built on proven Plotly Dash framework
🚀 Quick Start
Installation
pip install dash-ai-chat[openai]
Basic Usage
from dash_ai_chat import DashAIChat
# Set your OPENAI_API_KEY environment variable
app = DashAIChat(base_dir="./chat_data")
if __name__ == "__main__":
app.run(debug=True)
That's it! Visit http://localhost:8050 to start chatting.
Examples are worth a thousand words!
Explore the comprehensive examples to see what's possible:
- 00_minimal_chat.py - The absolute quickest way to get a fully-functional AI chat system running with just 3 lines of code
- 01_python_assistant.py - Create specialized AI assistants with custom system prompts, demonstrating how to build a Python programming helper named PyHero
- 02_disclaimer_chat.py - Add custom UI elements like disclaimers and warnings to your chat interface without breaking existing functionality
- 03_gemini_provider.py - Switch to Google's Gemini AI with just two configuration parameters, showing how easy provider switching can be
- 04_signature_chat.py - Extract token usage from API responses and add professional signatures to assistant messages with custom styling
- 05_anthropic_model_selector.py - Configure Anthropic Claude models with runtime switching capabilities and interactive model selection dropdowns
- 06_runtime_provider_switching.py - Dynamically switch between OpenAI, Anthropic, and Gemini providers and their models mid-conversation with simple attribute assignments
- 07_interactive_components.py - Embed interactive Dash components like dropdowns and buttons directly into AI responses for enhanced user engagement
- 08_corporate_dashboard.py - Complete enterprise-grade dashboard showcasing the extreme customization possibilities with corporate branding, navigation, and multi-panel layouts
- 09_zen_minimal.py - Minimalist design aesthetic demonstrating creative UI possibilities with floating elements, split-screen views, and zen-like simplicity
Running Examples
git clone https://github.com/eliasdabbas/dash-ai-chat.git
cd dash-ai-chat
# Create and activate virtual environment
python3 -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install with all providers
pip install -e .[openai,anthropic,gemini]
# Try any example
python examples/00_minimal_chat.py
Provider Support
Install optional dependencies for different AI providers:
# OpenAI (GPT models)
pip install dash-ai-chat[openai]
# Anthropic (Claude models)
pip install dash-ai-chat[anthropic]
# Google Gemini
pip install dash-ai-chat[gemini]
# All providers
pip install dash-ai-chat[openai,anthropic,gemini]
What is it?
The dash-ai-chat library is a Dash app distributed as a Python package.
It contains basic UI elements and data persistence logic, and designed to be entirely customizable.
The default implementation contains only the essential elements with basic defaults, and pretty much everything is designed to be customized and changed.
Additional interactivity can easily be introduced using standard Dash callbacks. If you know Dash, it should be easy to pick up.
Core API
Basic Configuration
from dash_ai_chat import DashAIChat
app = DashAIChat( # A Dash sub-class
base_dir="./chat_data", # Chat storage directory
provider_spec="openai:chat.completions", # AI provider specification
provider_model="gpt-4o", # Default model
**kwargs # Additional Dash app parameters
)
Customization
General workflow:
- Create a class (sub-class of
DashAIChat):
from dash_ai_chat import DashAIChat
class MyCustomAIChat(DashAIChat):
def default_method(self, ...):
default_data = super().default_method()
# add custom logic to default_data
- Create an
appinstance, just you like you do with Dash:
app = MyCustomAIChat(base_dir="my_base_dir")
if __name__ == "__main__":
app.run(debug=True)
In more detail:
Custom System Messages
class MyAssistant(DashAIChat):
# override the default load_messages method:
def load_messages(self, user_id: str, conversation_id: str):
# default_data:
messages = super().load_messages(user_id, conversation_id)
# futher logic to customize what to do with loaded messages
if not messages:
messages = [{
"role": "system",
"content": "You are a helpful Python programming assistant."
}]
return messages
UI Customization
Override any component to customize the interface:
from dash import html
class CustomChat(DashAIChat):
def header(self):
default_header = super().header()
return html.Div([
html.H1("My Custom Chat", className="text-center"),
html.Hr(),
default_header
])
def input_area(self):
# Add custom elements to input area
original = super().input_area()
disclaimer = html.Div("AI responses may contain errors")
return html.Div([original, disclaimer])
Architecture
Dash AI Chat uses a clean, extensible architecture:
- DashAIChat: Main application class with overridable methods
- Provider System: Pluggable AI provider backends
- Message Storage: JSON-based persistent chat history
- Component System: Override any UI component
Advanced Usage
Custom Providers
class MyCustomProvider:
def client_factory(self):
# Create your AI client
return YourAIClient(api_key="your-key")
def call(self, client, messages, model, **kwargs):
# Call your AI API
return client.chat(messages=messages, model=model, **kwargs)
def extract(self, response):
# Extract text from API response
return response.choices[0].message.content
def format_messages(self, messages):
# Format messages for your API
return messages
# Register and use your provider
app = DashAIChat(base_dir="./chat_data")
app.AI_REGISTRY["custom:provider"] = MyCustomProvider()
app.provider_spec = "custom:provider"
Ready to build amazing AI chat interfaces? Start with the examples and customize to your heart's content! 🚀
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dash_ai_chat-0.0.4.tar.gz.
File metadata
- Download URL: dash_ai_chat-0.0.4.tar.gz
- Upload date:
- Size: 5.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.21
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d5e991fe7bfd7218c70bbb9bb28ebb67b7ef61bd21c21e6d7f1edfd3e1a20456
|
|
| MD5 |
bb004b47d6d73f7f2cfcb4b057c1e5e8
|
|
| BLAKE2b-256 |
f884d240f48ead761d857e80e7f2312c64c9dc57d6742e11e4017602a2548730
|
File details
Details for the file dash_ai_chat-0.0.4-py3-none-any.whl.
File metadata
- Download URL: dash_ai_chat-0.0.4-py3-none-any.whl
- Upload date:
- Size: 13.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.21
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
14d1f09c0f65cdeb5ee19bee581f639f0607d010bd07d5cceb029db210886aef
|
|
| MD5 |
5b08850c68f3a90f58e807e29ad6b814
|
|
| BLAKE2b-256 |
80c665ac742342168790a6adeb225eb5ae4cd0a414a725c17a250cc76d12b641
|