Skip to main content

Add htmx + DaisyUI based UI to FastAPI with pure Python

Project description

logo

PyPI version Python 3.11+ License: MIT

Add beautiful UI to FastAPI with pure Python. No JavaScript, no templates, no frontend build step.

Quick Start

pip install kokage-ui            # core
pip install kokage-ui[all]       # SQL + LangChain + Markdown support
from fastapi import FastAPI
from kokage_ui import KokageUI, Page, Card, H1, P, DaisyButton

app = FastAPI()
ui = KokageUI(app)

@ui.page("/")
def home():
    return Page(
        Card(
            H1("Hello, World!"),
            P("Built with FastAPI + htmx + DaisyUI. Pure Python."),
            actions=[DaisyButton("Get Started", color="primary")],
            title="Welcome to kokage-ui",
        ),
        title="Hello App",
    )
uvicorn hello:app --reload

Please open http://localhost:8000 in your browser.

CRUD in 10 Lines

Define a Pydantic model and get full CRUD UI automatically:

from fastapi import FastAPI
from pydantic import BaseModel, Field
from kokage_ui import KokageUI, InMemoryStorage

app = FastAPI()
ui = KokageUI(app)

class Todo(BaseModel):
    id: str = ""
    title: str = Field(min_length=1)
    done: bool = False

ui.crud("/todos", model=Todo, storage=InMemoryStorage(Todo))

This single ui.crud() call generates list, create, detail, edit, and delete pages with search and pagination — all styled with DaisyUI.

https://github.com/user-attachments/assets/4c4ad3be-664d-432e-9c2e-23e80755b461

Switch to SQLite for real persistence — same API, just swap the storage:

from sqlalchemy.ext.asyncio import create_async_engine
from sqlmodel import SQLModel, Field
from kokage_ui import SQLModelStorage

class Todo(SQLModel, table=True):
    id: int | None = Field(default=None, primary_key=True)
    title: str = Field(min_length=1)
    done: bool = False

engine = create_async_engine("sqlite+aiosqlite:///data.db")
ui.crud("/todos", model=Todo, storage=SQLModelStorage(Todo, engine))

pip install kokage-ui[sql] for SQLModel support.

Streaming Chat UI

Build an LLM chat interface with SSE streaming in a few lines:

from fastapi import FastAPI
from kokage_ui import KokageUI

app = FastAPI()
ui = KokageUI(app)

@ui.chat("/chat")
async def chat(message: str):
    async for token in your_llm(message):  # OpenAI, Anthropic, etc.
        yield token

ui.chat() auto-generates the page with DaisyUI chat bubbles, SSE streaming, Markdown rendering, and code highlighting.

https://github.com/user-attachments/assets/d14d487c-a694-4159-9486-24caccb77a9b

AI Agent View

Build an agent dashboard with tool call visualization:

from fastapi import FastAPI
from kokage_ui import KokageUI
from kokage_ui.ai import AgentEvent

app = FastAPI()
ui = KokageUI(app)

@ui.agent("/agent")
async def agent(message: str):
    yield AgentEvent(type="tool_call", call_id="1", tool_name="search", tool_input=message)
    result = await your_tool(message)
    yield AgentEvent(type="tool_result", call_id="1", result=result)
    async for token in your_llm(message, result):
        yield AgentEvent(type="text", content=token)
    yield AgentEvent(type="done", metrics={"tokens": 150, "tool_calls": 1})

ui.agent() renders a full agent UI with status bar, collapsible tool call panels, streaming Markdown, and execution metrics.

https://github.com/user-attachments/assets/1dfbe1ec-eb87-447f-9c4c-17f16d2d123b

LangChain / LangGraph Integration

Connect to LangChain or LangGraph with built-in adapters — no boilerplate event mapping:

from kokage_ui.ai.langchain import langchain_agent_stream

# executor = AgentExecutor (LangChain's agent runner with tools and LLM)
@app.post("/api/agent")
async def run(request: Request):
    data = await request.json()
    events = executor.astream_events({"input": data["message"]}, version="v2")
    return langchain_agent_stream(events)
from kokage_ui.ai.langgraph import langgraph_agent_stream

# graph = LangGraph's CompiledStateGraph (e.g. from create_react_agent)
@app.post("/api/agent")
async def run(request: Request):
    data = await request.json()
    stream = graph.astream({"messages": [("user", data["message"])]}, stream_mode="messages")
    return langgraph_agent_stream(stream)

Also includes LangChainCallbackHandler for legacy AgentExecutor and ToolRegistry + to_langchain_tools for bidirectional tool conversion.

pip install kokage-ui[langchain] for LangChain support, or pip install kokage-ui[all] for everything.

Features

  • 50+ HTML ElementsDiv, H1, Form, Input, etc. as Python classes
  • 25+ DaisyUI ComponentsCard, Hero, NavBar, Modal, Tabs, Accordion, Toast, Layout, and more
  • Pydantic → UI — Auto-generate forms, tables, detail views from BaseModel
  • One-line CRUDui.crud("/users", model=User, storage=storage)
  • DataGrid — Sortable, filterable table with pagination, bulk actions, CSV export
  • Admin Dashboard — Django-like admin panel: AdminSite(app).register(User, storage=s)
  • Auth UILoginForm, RegisterForm, UserMenu, RoleGuard, @protected decorator
  • Theme SystemDarkModeToggle and ThemeSwitcher with localStorage persistence
  • Real-time Notifications — SSE-based push notifications via Notifier + NotificationStream
  • SQLModel Storage — Async database persistence with SQLModelStorage
  • htmx PatternsAutoRefresh, SearchFilter, InfiniteScroll, SSEStream, ConfirmDelete
  • Charts & MarkdownChart (Chart.js), CodeBlock (Highlight.js), Markdown
  • Multi-step FormsMultiStepForm with step validation
  • CLI Scaffoldingkokage-ui init myapp to generate project templates
  • XSS Protection — Output escaped via markupsafe by default

CLI

Scaffold a new project in seconds:

uvx kokage-ui init myapp                    # Minimal app with Card
uvx kokage-ui init myapp -t crud            # CRUD app with model & storage
uvx kokage-ui init myapp -t admin           # Admin dashboard with SQLite
uvx kokage-ui init myapp -t dashboard       # KPI stats & Chart.js charts
uvx kokage-ui init myapp -t chat            # AI chat with SSE streaming
uvx kokage-ui init myapp -t agent           # AI agent with tool execution

Add pages and models to an existing project:

uvx kokage-ui add page dashboard            # Add a new page
uvx kokage-ui add crud Product              # Add CRUD model
uvx kokage-ui templates                     # List all available templates

Examples

Example Description Run
hello.py Minimal app uvicorn examples.hello:app
todo.py CRUD todo app uvicorn examples.todo:app
dashboard.py Full dashboard uvicorn examples.dashboard:app
admin_demo.py Admin panel (SQLite) uvicorn examples.admin_demo:app
auth_demo.py Auth + Admin uvicorn examples.auth_demo:app
blog.py Markdown + Charts + Tabs uvicorn examples.blog:app
realtime.py SSE notifications uvicorn examples.realtime:app
chat_demo.py Streaming chat UI uvicorn examples.chat_demo:app
agent_demo.py AI agent with tools uvicorn examples.agent_demo:app
langchain_demo.py LangChain/LangGraph adapters uvicorn examples.langchain_demo:app
chart_demo.py Chart.js 6 chart types uvicorn examples.chart_demo:app

Documentation

For detailed guides, component reference, and API docs, see the full documentation.

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

kokage_ui-0.7.0.tar.gz (281.9 kB view details)

Uploaded Source

Built Distribution

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

kokage_ui-0.7.0-py3-none-any.whl (150.9 kB view details)

Uploaded Python 3

File details

Details for the file kokage_ui-0.7.0.tar.gz.

File metadata

  • Download URL: kokage_ui-0.7.0.tar.gz
  • Upload date:
  • Size: 281.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for kokage_ui-0.7.0.tar.gz
Algorithm Hash digest
SHA256 f792a44e6b8232768ea3e195dd23bf8547bb61cf72bd52dcc4f57a97b309b5a7
MD5 b8fe4a28843a65d537cdd42121c737ef
BLAKE2b-256 1704959f91e4551d60162007147c1231b2fad3c4ef3c1d1ef97934f485b2e61d

See more details on using hashes here.

File details

Details for the file kokage_ui-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: kokage_ui-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 150.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for kokage_ui-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 df4fb398732ef5229c3dc3e69607be5b1a54a94dd912eebd4a72bb0c1d176a25
MD5 ed62a570635caf365fa35230043f6b7f
BLAKE2b-256 3d0421900016d508600ad26a4366cebab41f5adf97ba66482dd89f7fbdc5c57b

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