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

Uploaded Python 3

File details

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

File metadata

  • Download URL: lokutui-0.1.4.tar.gz
  • Upload date:
  • Size: 8.8 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.4.tar.gz
Algorithm Hash digest
SHA256 59dd1d20607ee787b26fd660311a0cd29fb6b125476c13ec0b4523fdb1fd481b
MD5 b58a2808df7e7d7d5c378738eae41d88
BLAKE2b-256 d7f3137c45f1e7d22c5f5f2e9d95f64ef88c633a39dfa9b36510f1c8f8d4b99a

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: lokutui-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 10.1 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 260907f8905204fe6a88f733b22eda7b25a219f0f4f11fe8c388dd573ac29857
MD5 e8f03fbf7fbf9dbc7201e6af9f17ba1c
BLAKE2b-256 99cb2372150128ec9ad0e98f2a462ca525a0d56eff1d85d1f550374fe8f15244

See more details on using hashes here.

Provenance

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