Skip to main content

Clack-style terminal UI primitives for prompt-first Python TUIs.

Project description

griphtui

Minimal and ergonomic Clack-style terminal UI primitives for Python CLIs/TUIs.

Install

uv add griphtui

The basics

GriphTUI is heavily inspired by Clack, and follows many of the same basic principles.

You'll probably want to begin with an intro:

import griphtui as gtui

gtui.intro("The grand survey")

...after which you can employ a range of primitives to prompt the user:

# section header
gtui.section("Let's talk about trains")

# text input
gtui.text("What's your favorite train?")

# select
gtui.select(
    "Can this train drift?",
    [("Probably", "probably"), ("Definitely", "definitely")]
)

# multiselect
gtui.select(
    "Which of the following applies to your favorite train?",
    [
        ("I wish it could drift", "wish", True), # toggled on by default
        ("I'm sad that it can't drift", "sadness", False)
        ("It's really nice that it can drift", "happiness", False)
    ]
)

# spinners
with gtui.spinner("Preparing for ethical dilemmas...") as s:
    time.sleep(1)
    s.update("Installing drift capabilities...")
    time.sleep(1)
    s.update("Updating Terms of Use...")

# status messages
gtui.warn("Aristoteles disliked this") # info, step, success, warn or error

Finally, wrap up with an outro:

gtui.outro("Thanks for playing")

API

Function Purpose
intro(title) / outro(msg) / section(title) frames
text(label, default="") single-line input
password(label) masked input
confirm(label, default=True) y/n prompt
select(label, options) single-choice picker
multiselect(label, options) multi-choice picker
spinner(label) threaded spinner context manager
info / step / success / warn / error prefixed status lines

All prompts accept an optional console= kwarg if you want to inject your own Rich Console.

Platforms

Linux, macOS, and Windows (uses msvcrt for raw input on Windows, termios/tty elsewhere).

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

griphtui-0.1.1.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

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

griphtui-0.1.1-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file griphtui-0.1.1.tar.gz.

File metadata

  • Download URL: griphtui-0.1.1.tar.gz
  • Upload date:
  • Size: 25.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for griphtui-0.1.1.tar.gz
Algorithm Hash digest
SHA256 c8e4efdfdcd5b28ba5d90e0723a2328ec03a874d5f0dd6cc7bc26c4c0623e63e
MD5 c859d6473a7e489d90bd455567f4696e
BLAKE2b-256 d092fd1deade132abfa0dbd665c8006137b1a731ad4ca4066ad535740aeade3c

See more details on using hashes here.

Provenance

The following attestation bundles were made for griphtui-0.1.1.tar.gz:

Publisher: publish.yml on bhark/griphTUI

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

File details

Details for the file griphtui-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: griphtui-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 20.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for griphtui-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7afd31c85e8e8d759ac4857ea44e476dfaf906d51f33907a7fe65f563e84949c
MD5 858d3b2fd48557fbd346e345c1f7b722
BLAKE2b-256 c08da11b1076fc07743cabb2512e027a66e90a5c2cf9d1b6c0fa89d3c53adffb

See more details on using hashes here.

Provenance

The following attestation bundles were made for griphtui-0.1.1-py3-none-any.whl:

Publisher: publish.yml on bhark/griphTUI

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