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 🧪

About

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

Development Requirements

  • python >=3.7,<4
  • poetry

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.2.0.tar.gz (7.1 kB view hashes)

Uploaded Source

Built Distribution

textual_forms-0.2.0-py3-none-any.whl (8.0 kB view hashes)

Uploaded Python 3

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