Skip to main content

Visual effects for Textual, a TermincalTextEffects wrapper.

Project description

textualeffects

Visual effects for Textual, a TerminalTextEffects wrapper.

Intro

textualeffects is a library that provides Textual bindings for the excellent TerminalTextEffects visual effects library.

Widgets

There are two widgets available in textualeffects, EffectLabel and SplashScreen.

An EffectLabel widget that can be used to display text with a visual effect.

from textual.app import App, ComposeResult

from textualeffects.effects import EffectType
from textualeffects.widgets import EffectLabel

text=("Hello World! " * 5 + "\n") * 10,
effect: EffectType = "Spotlights"
config = {
    "search_duration": 500,
    "spotlight_count": 3,
}


class TextualEffect(App):

    def compose(self) -> ComposeResult:
        label = EffectLabel(text, effect=effect, config=config)
        label.styles.border = ("heavy", "green")
        yield label


if __name__ == "__main__":
    app = TextualEffect()
    app.run()

EffectLabel

A SplashScreen widget that can be used to display a splash screen based on ModalScreen with a visual effect. Once the effect is complete, the splash screen will be dismissed.

from textual.app import App, ComposeResult
from textual.widgets import TextArea

from textualeffects.effects import EffectType
from textualeffects.widgets import SplashScreen

effect: EffectType = "Spotlights"
config = {
    "search_duration": 100,
    "spotlight_count": 3,
}


class SplashEffect(App):

    def on_mount(self) -> None:
        text = ("Hello World! " * 5 + "\n") * 10
        self.push_screen(SplashScreen(text, effect=effect, config=config))

    def compose(self) -> ComposeResult:
        yield TextArea(("Main content" * 5 + "\n") * 10)


if __name__ == "__main__":
    app = SplashEffect()
    app.run()

EffectLabel

Both widgets accept the following arguments:

  • text: The text to display.
  • effect: The visual effect to apply to the text. Available effects are exposed through the EffectType type.
  • config: A dictionary of configuration options for the effect. The available options depend on the effect. Detailed information on the available options can be found in the TerminalTextEffects documentation.

For convenience, when an effect has run its course, the EffectLabel and SplashScreen widgets will emit a EffectLabel.EffectFinished event. You can listen for this event to perform any actions:

    @on(EffectLabel.EffectFinished)
    def do_stuff(self, message: EffectLabel.EffectFinished) -> None:
        ...

License

This project is licensed under the MIT License.

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

textualeffects-0.1.2.tar.gz (40.7 kB view details)

Uploaded Source

Built Distribution

textualeffects-0.1.2-py3-none-any.whl (4.9 kB view details)

Uploaded Python 3

File details

Details for the file textualeffects-0.1.2.tar.gz.

File metadata

  • Download URL: textualeffects-0.1.2.tar.gz
  • Upload date:
  • Size: 40.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.4.16

File hashes

Hashes for textualeffects-0.1.2.tar.gz
Algorithm Hash digest
SHA256 040709d887a9e86860401e0f57429d231a5598e8c176089c99315ab99af1b229
MD5 b19081d73bbf39a049a3b5ff326f8284
BLAKE2b-256 89ab4f713c2258a056d6e94fe4896b8382ec9952a963898a6fc39e1020580278

See more details on using hashes here.

File details

Details for the file textualeffects-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for textualeffects-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 44bddf26f75dc6b0b472e9169113433b6281893cc3e6d2877ce262bad95788de
MD5 901a79e51ed3c994cec13563c9d48106
BLAKE2b-256 c2e39bc115396e6aaa6bf206c60fade2ce4c531ef5a510482f4db6230c3a636e

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