Skip to main content

A native python tui library

Project description

Lokutui

Lokutui is a lightweight Python library for building native terminal user interfaces (TUIs) using curses. It provides core screen management, an event system, and a collection of common widgets that can be composed to build interactive text‑based applications.

Installation

Lokutui is distributed via PyPI;

pip install lokutui

Alternatively, include it directly as a dependency in your project or install from source.

Core concepts

Screen

Screen is the entry point for any application. It handles curses initialization, the main loop, input polling, rendering, and event dispatching. Typical usage:

from lokutui.core import Screen

screen = Screen()

# add widgets
# screen.add_widget(my_widget)

screen.run()

The run method accepts an optional initial_setup_callback where you can configure widgets before the loop starts. Call screen.exit() from any handler to terminate the application.

Screen also supports a simple loading overlay and a modal widget you can assign to screen.modal.

Widget

All visual elements inherit from the base Widget class. A widget has position (x, y), optional size (width, height), and visibility. Widgets must implement render(stdscr, max_y, max_x) and may override handle_event(event) to react to input.

Event system

Events are instances of a simple named tuple with type and data. The library provides helpers for creating key, mouse and custom events:

from lokutui.events import create_key_event, CustomEvent

EventDispatcher is a singleton used by the screen to dispatch events to registered handlers. You can register handlers and post events either directly or by using the global queue:

from lokutui.events import EventDispatcher

dispatcher = EventDispatcher()
def on_key(e):
    ...
dispatcher.register_handler('key', on_key)

Handlers are called for each event type when Screen processes the queue.

Widgets

Lokutui includes a number of built‑in widgets located in lokutui.widgets:

  • Label – render static text at a position with optional width and color.
  • Box – draw a bordered rectangle.
  • Frame – a Box with an optional title.
  • Button – clickable text; supports focus/highlight and invokes an on_click callback.
  • TextInput – single‑line editable input field with basic cursor movement and text editing.
  • List – scrollable list of strings; arrow keys or j/k to navigate, ENTER to select.
  • Select – horizontal chooser cycling through options with left/right or h/l keys.
  • Checkbox – toggleable checkbox with label.
  • VStack/HStack – layout containers stacking child widgets vertically or horizontally.
  • Dialog – simple yes/no modal dialog.
  • FormDialog – multi‑field modal form with save/cancel buttons.
  • LogDisplay – scrollable log window for output messages.
  • ProgressBar – horizontal progress indicator.
  • Chart – very basic line chart using braille characters.

Each widget accepts positioning and sizing arguments, color pair indices for curses attributes, and optional callbacks for interactions (on_click, on_select, on_change, etc.).

Example of building a simple form:

from lokutui.core import Screen
from lokutui.widgets import VStack, Label, TextInput, Button

screen = Screen()

name_input = TextInput(x=2, y=2, width=20)
submit = Button("Submit", x=2, y=4, on_click=lambda: screen.exit())

vstack = VStack([Label("Name:"), name_input, submit], x=1, y=1, spacing=1)
screen.add_widget(vstack)

screen.run()

Extending Lokutui

You can subclass Widget to create custom components. Implement rendering logic and event handling as needed and add instances to the Screen.

Contributing

Contributions are welcome. Please open issues or pull requests in the repository and follow standard Python packaging conventions.

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

lokutui-0.1.0.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

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

lokutui-0.1.0-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

Details for the file lokutui-0.1.0.tar.gz.

File metadata

  • Download URL: lokutui-0.1.0.tar.gz
  • Upload date:
  • Size: 8.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for lokutui-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1af0ae36544b1381b2dada47dfb701634e70895024caf861358d202a2c5349be
MD5 705fb9db170f4e6581283fe98478e94c
BLAKE2b-256 a654b2bb84ca5d32045c41f20ece83f5407152b798fe3841bd2f04671c3777d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for lokutui-0.1.0.tar.gz:

Publisher: workflow.yml on lokutor-ai/lokutui

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

File details

Details for the file lokutui-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: lokutui-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for lokutui-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1738c11bac010dc3fcf4acad861795d81dbf48025ee188f7d3a48ee2237d6b83
MD5 4f83a30ba7c4489da1c267212589058b
BLAKE2b-256 9eba5355bc0da4d812b9d64d102f1281fff12e8f120068069f52476b87defe4d

See more details on using hashes here.

Provenance

The following attestation bundles were made for lokutui-0.1.0-py3-none-any.whl:

Publisher: workflow.yml on lokutor-ai/lokutui

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