Skip to main content

Python library for building MCP App UIs — declarative components, themes, and MCP protocol client. Define an app in Python, get self-contained HTML.

Project description

mcpbundles-app-ui

Python library for building MCP App UIs. Define an app declaratively in Python, get self-contained HTML with built-in MCP protocol support and interactive charts.

Installation

pip install mcpbundles-app-ui

Quick Start

from mcpbundles_app_ui import App, LightTheme, Stats, Stat, Card

class MyApp(App):
    name = "My App"
    subtitle = "Analytics overview"
    theme = LightTheme(accent="#3b82f6")

    layout = [
        Stats(
            Stat("preview.total", "Total", primary=True),
            Stat("preview.thisWeek", "This Week"),
        ),
        Card(title="Select an option to explore"),
    ]

# Generate self-contained HTML
html = MyApp().render()

Features

  • Declarative components: Stats, Stat, Card, Grid, Chart.bar(), BarList, RecentList, and more
  • Theme system: LightTheme and DarkTheme with customizable accent colors, fonts, and all design tokens
  • Interactive charts: Built-in canvas chart engine (18 chart types, CSP-safe, zero dependencies) with declarative Python components
  • MCP protocol client: Built-in JavaScript for initializeMCP(), callTool(), sendMessage(), askAI()
  • Navigation: Breadcrumb system with setBreadcrumbs(), pushBreadcrumb(), popBreadcrumb()
  • Loading states: showLoading(), hideLoading(), withLoading(), paginateAll()
  • Export utilities: copyToClipboard(), toCSV(), exportAsCSV()
  • Toast notifications: showToast() for success/error feedback
  • Path-based assets: custom_head and custom_scripts accept Path objects for file-based CSS/JS
  • Zero Python dependencies: Only stdlib. Produces standalone HTML with all CSS/JS inline.

Charts

Charts are defined declaratively in your Python layout using Chart factory methods:

from mcpbundles_app_ui import Chart, Grid

layout = [
    Grid(cols=2)(
        Chart.bar("data.byMonth", title="Monthly Revenue"),
        Chart.comparison("data.thisWeek", "data.lastWeek", title="Week over Week"),
    ),
    Chart.funnel("data.pipeline", title="Sales Pipeline"),
    Chart.distribution("data.byCategory", title="Category Breakdown"),
]

The library includes two rendering engines:

  • Chart engine — 18 canvas chart types (candlestick, line, area, bar, column, dual axes, scatter, pie, treemap, radar, histogram, heatmap, funnel, table, and 4 card types). Used by chart-driven apps where the user controls views via dropdowns and selectors.
  • Tabbed engine — Multi-tool apps where each tab calls a different MCP tool. Charts render within tab content areas with a shared period toolbar.

Charts automatically use the app's theme colors (--chart-1 through --chart-6).

Components

Component Description
App Base class for app definitions
Stats Row of statistic cards
Stat Single statistic with data binding
Card Container with optional title
Grid Grid layout (2-4 columns)
Section Named section with header and subtitle
Chart.bar() Bar chart with data binding
Chart.comparison() Side-by-side comparison of two values
Chart.funnel() Pipeline/funnel stage chart
Chart.distribution() Distribution breakdown by category
ListPicker List selection component with callback
BarList Horizontal bar ranking list
RecentList Recent items list
StageList Pipeline stage list with bars
Raw Escape hatch for custom HTML
CustomScript Inject custom JavaScript

Themes

from mcpbundles_app_ui import LightTheme, DarkTheme

# Custom accent color
theme = LightTheme(accent="#8b5cf6")

# Custom fonts
theme = LightTheme(
    accent="#3b82f6",
    font_family="'Inter', system-ui, sans-serif",
    font_url="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap",
)

File-Based Assets

Load CSS/JS from files instead of inline strings:

from pathlib import Path
from mcpbundles_app_ui import App, LightTheme

class MyApp(App):
    name = "My App"
    theme = LightTheme()
    custom_head = Path(__file__).parent / "assets/styles.html"
    custom_scripts = Path(__file__).parent / "assets/app.js"

License

MIT

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

mcpbundles_app_ui-0.9.0.tar.gz (54.2 kB view details)

Uploaded Source

Built Distribution

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

mcpbundles_app_ui-0.9.0-py3-none-any.whl (63.2 kB view details)

Uploaded Python 3

File details

Details for the file mcpbundles_app_ui-0.9.0.tar.gz.

File metadata

  • Download URL: mcpbundles_app_ui-0.9.0.tar.gz
  • Upload date:
  • Size: 54.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mcpbundles_app_ui-0.9.0.tar.gz
Algorithm Hash digest
SHA256 67926925c11fe4fb1558c843cd9d00e1d152fed32dc1c009cae7374e5c0486f7
MD5 948963eaa93eeaf35ef1784779cb57a3
BLAKE2b-256 59f6159967204ecb0012fbe16fd8b0e0e31f5bc570ea98457d0baa19d6faf4fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcpbundles_app_ui-0.9.0.tar.gz:

Publisher: publish.yml on thinkchainai/mcpbundles-app-ui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcpbundles_app_ui-0.9.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mcpbundles_app_ui-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fa19779545ed88db4978e864db4906ad1d93d19a914ef01f3be69c65bda07e34
MD5 fc0a5e820f3961b56e48e460b035d862
BLAKE2b-256 c4b21f2b3d23f860a9cae65463fa6815107758bcbea454894e8ac35f7ac45eb5

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcpbundles_app_ui-0.9.0-py3-none-any.whl:

Publisher: publish.yml on thinkchainai/mcpbundles-app-ui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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