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.7.tar.gz (9.6 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.7-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: lokutui-0.1.7.tar.gz
  • Upload date:
  • Size: 9.6 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.7.tar.gz
Algorithm Hash digest
SHA256 45ca54cf5da4995be3fdc847f5974854eb86db76eb19995a040c520677974bc2
MD5 83c944092fd8f7da88cd626d15124272
BLAKE2b-256 f8a45f3bc37cfa2b1c8d07226a1ff0b91ee5aac0b1915c7503898a1302e0ac81

See more details on using hashes here.

Provenance

The following attestation bundles were made for lokutui-0.1.7.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.7-py3-none-any.whl.

File metadata

  • Download URL: lokutui-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 10.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.7-py3-none-any.whl
Algorithm Hash digest
SHA256 4ddbdfcf4ae8a947ea3ef1ba26941736f5bbacc0da79b4684b53ec51c38f21e4
MD5 65ee7b55dc09854e63b8343de144187f
BLAKE2b-256 0b1bd435f4305fa22813584389a2a6c0a7a910d303fb69528133bb2afc2fc9e3

See more details on using hashes here.

Provenance

The following attestation bundles were made for lokutui-0.1.7-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