Skip to main content

A lightweight, dependency-light Python TUI library with a cell-grid renderer and VT input.

Project description

cozy_tui

CI (Windows · macOS · Linux) PyPI version Python versions GitHub stars

A lightweight, cross-platform Python TUI (Terminal User Interface) library. Build keyboard-driven terminal apps with widgets, focus management, mouse support, and smooth cursor blinking — all rendered through raw VT sequences. Runs on Windows (Console API) and POSIX (Linux/macOS via termios).


Documentation

Full documentation lives in docs/ (GitHub) directory:

  • Core Concepts — the render loop, coordinate system, and widget lifecycle.
  • Widgets — every widget: App, Box, Label, Hyperlink, Bindings, Text, Input, Button, Checkbox, MarkdownInput, ListView, CheckList, RadioSet, Dropdown, ProgressBar, Table, Collapsible, Tree, AnimatedLabel.
  • Layouts, Dock & OverlaysVBox/HBox/Grid, app.dock(...), and the overlay/modal layer (open_overlay, app.prompt).
  • StylingStyle, colors, and text attributes.
  • Input & Interaction — key bindings, mouse support, focus, and scrolling.
  • Examples — runnable demos in examples/.

Features

  • Cross-platform — runs on Windows (Console API) and POSIX (Linux/macOS via termios); the backend is chosen automatically.
  • Very few dependencies — the clipboard is built in (no pyperclip); the only third-party dependency is rich, used to render Markdown/MarkdownInput. Everything else is the standard library.
  • Built-in clipboardcozy_tui.clipboard.copy/paste with native backends per platform (Win32 API, pbcopy/pbpaste, wl-clipboard/xclip/xsel, or OSC 52 fallback).
  • Unicode-aware rendering — a built-in wcwidth-style width layer keeps CJK/emoji (double-width) and combining marks (zero-width) aligned in the cell grid.
  • Widgets: Button, Checkbox, Input, Label, Hyperlink, Bindings, AnimatedLabel, Text, Box, MarkdownInput, ListView, CheckList, RadioSet, Dropdown, ProgressBar, Table, Collapsible, Tree
  • Layouts: VBox, HBox, Grid — auto-position children without manual x/y
  • Dock layout: app.dock(widget, "top"/"bottom"/"left"/"right"/"fill") — edge-anchored regions that re-flow on resize
  • Overlays & modals: app.open_overlay(widget) floats a widget above the UI, dims the background, and confines focus/input — the basis for dialogs, menus, and tooltips
  • Multi-line Input: Enter or Shift+Enter to insert newlines, UP/DOWN to navigate lines
  • Markdown preview: MarkdownInput renders live Rich Markdown when unfocused
  • Focus system: Tab / Shift+Tab to cycle focus, click to focus with mouse
  • Cursor blinking: Uses the real terminal cursor — smooth blink with no character replacement
  • Mouse support: Click to focus widgets, click to activate buttons, scroll wheel to scroll
  • Scrolling: Long content scrolls vertically; single-line inputs scroll horizontally
  • Global key handlers: Register app-wide shortcuts with app.on_key()
  • Flexible styling: Per-widget foreground, background, and text styles (bold, dim, underline)


Requirements

  • Python 3.10+
  • A VT-capable terminal on Windows (Windows Console API) or POSIX (Linux/macOS, via termios/tty). The console backend is selected automatically at import.


Installation

pip install cozy-tui

That's it — rich (used to render Markdown / MarkdownInput) is pulled in automatically.

Take it for a spin with the built-in demo:

python -m cozy_tui

Then in your script:

from cozy_tui import App, Style
from cozy_tui.widgets import Box, Label, Input, Button

From source (for development)

git clone https://github.com/youssefahmed2017/cozy_tui.git
cd cozy_tui
pip install -e .            # add [dev] for the test suite (pytest)


Quick Start

from cozy_tui import App, Style
from cozy_tui.widgets import Box, Label, Input, Button, Checkbox
from cozy_tui.events import Key

app = App(full=True, size=None, style=Style(fg="white", bg="black"))

# Box size = virtual pixels ÷ App.SCALE (10) → "600x140" = 60 cols × 14 rows
box = Box(2, 1, "600x140", border="rounded", style=Style(fg="white", bg="black"), title="Sign Up")

box.add(Label(2, 2, "Username:"))
box.add(Input(12, 2, 20, placeholder="Enter username"))

box.add(Label(2, 4, "Bio:"))
box.add(Input(12, 4, 20, placeholder="Tell us about you", multiline=True))

box.add(Checkbox(2, 7, "Subscribe to newsletter"))
box.add(Checkbox(2, 9, "I agree to the terms", checked=True))

btn = Button(2, 11, "Submit", width=20, style=Style(fg="white", bg="blue"))
btn.on_click(lambda b: print("Submitted!"))
box.add(btn)

app.add(box)
app.focus(btn)
app.on_key(Key.ESC, lambda: "quit")
app.run()

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

cozy_tui-0.3.0.tar.gz (78.2 kB view details)

Uploaded Source

Built Distribution

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

cozy_tui-0.3.0-py3-none-any.whl (81.1 kB view details)

Uploaded Python 3

File details

Details for the file cozy_tui-0.3.0.tar.gz.

File metadata

  • Download URL: cozy_tui-0.3.0.tar.gz
  • Upload date:
  • Size: 78.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for cozy_tui-0.3.0.tar.gz
Algorithm Hash digest
SHA256 5051c81b5e86ee0edfbf929ec15b1f9b5e2617a294283e5ca8ab92ba93427d99
MD5 49ccef2a0d494e42d8809f9cfdec88c1
BLAKE2b-256 25b07a3d6f57ddc951ff99bae9df9d958dd7d42cdb4ee502044d80ec6a449144

See more details on using hashes here.

File details

Details for the file cozy_tui-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: cozy_tui-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 81.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for cozy_tui-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 71451762256ee43c1dd9c32e9bf0a6722467eab155281c78930c4b17dcc14c3a
MD5 b2b644dcb18f048df49b4824bd3a8428
BLAKE2b-256 fb04325e149a4ec9257ea3283de9a280bcffb2df1a5f145e5cb3bc6e262b4c26

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