Skip to main content

Dynamic forms for Textual TUI Framework

Project description

Textual Forms

Python Versions License: MIT Downloads Downloads

Dynamic forms for Textual TUI framework.

Note: This library is still very much WIP 🧪. This means that breaking changes can be introduced at any point in time.

About

Textual Forms aims to make it easy to add forms to your Textual-powered applications.

Development Requirements

  • python >=3.7,<4
  • poetry
  • textual >=0.11.0

Install

pip install textual-forms

Forms

textual_forms.forms.Form

Buttons

textual_forms.buttons.Button

Fields

textual_forms.fields.StringField

textual_forms.fields.NumberField

textual_forms.fields.IntegerField

Custom fields and validators

from __future__ import annotations

from typing import Any

from textual_forms.fields import Field
from textual_forms.validators import FieldValidator


class UUIDValidator(FieldValidator):
    def validate(self, value: str, rules: dict[str, Any]) -> tuple[bool, str | None]:
        return True, None


class UUIDField(Field):
    validator = UUIDValidator()

    def __init__(
        self,
        name: str,
        *,
        value: str | None = None,
        required: bool = False,
        placeholder: str | None = None,
        **kwargs,
    ):
        data: dict[str, Any] = {
            "name": name,
            "value": value,
            "required": required,
            "placeholder": placeholder,
            "rules": {},
        }
        super().__init__(data, **kwargs)

Example

from rich.table import Table
from textual.app import App, ComposeResult
from textual.widgets import Static

from textual_forms.forms import Form
from textual_forms.fields import StringField, IntegerField
from textual_forms.buttons import Button


class BasicTextualForm(App):
    def compose(self) -> ComposeResult:
        yield Static(id="submitted-data")
        yield Static("Order for beers")
        yield Form(
            fields=[
                StringField("name"),
                IntegerField("age", required=True, min_value=21),
            ],
            buttons=[
                Button(
                    "Submit",
                    enabled_on_form_valid=True,
                )
            ],
        )

    def on_form_event(self, message: Form.Event) -> None:
        if message.event == 'submit':
            table = Table(*message.data.keys())
            table.add_row(*message.data.values())
            self.query_one('#submitted-data').update(table)


if __name__ == '__main__':

    BasicTextualForm().run()

Initial render Screenshot 2022-11-15 at 3 49 46 PM

Valid form Screenshot 2022-11-15 at 3 51 15 PM

Invalid form Screenshot 2022-11-15 at 3 51 39 PM

Contributing

TBD

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

textual_forms-0.3.0.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

textual_forms-0.3.0-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: textual_forms-0.3.0.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.7.15 Linux/5.15.0-1033-azure

File hashes

Hashes for textual_forms-0.3.0.tar.gz
Algorithm Hash digest
SHA256 d41b884c69cb0042a0cf6835338435435811e6dc06cfd7c0a44a766dbddf54f3
MD5 c6b25093f65f7b65b88d80a273ad8445
BLAKE2b-256 1a62846ac6b2082291a8debb05bf0c86343a5929c8b28076d4e98c70db0c3351

See more details on using hashes here.

File details

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

File metadata

  • Download URL: textual_forms-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.7.15 Linux/5.15.0-1033-azure

File hashes

Hashes for textual_forms-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9b886d38497d2d34f71fefa17ada5d44e54f13ea20b80bb328c9919ebc77da8f
MD5 7ba4a4211d3ab3719cc03a5c9d7c1086
BLAKE2b-256 18f8454a0b6a0d12c22917933528d003247f062093ea414ceb79849934ce2787

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page