Skip to main content

A tool to design and run dynamic, customizable dashboards directly inside your terminal.

Project description


🖥 Terminal Widgets

This tool lets you design and run dynamic, customizable dashboards directly inside your terminal. It combines modular widgets, real-time data updates, and flexible layout management for a highly interactive CLI experience.

Getting startedConfigurationAdding new widgetsLicense


Example Image of Terminal Widgets

Stats Stats Stats Stats Stats


🚀 1. Getting started

Installation from PyPI

  1. Install: pip install twidgets
  2. Initialize: twidgets init
  3. Run: twidgets

⚠️ Requires Python Version 3.10+

Installation from Source

  1. Clone this repository
  2. Install dependencies: pip install -r requirements.txt
  3. Initialize configuration: python -m twidgets init
  4. Run: python -m twidgets

⚠️ Requires Python Version 3.10+

For full documentation see Setup Guide


2. Configuration

2.1 Changing standard colors and configuration in ~/.config/twidgets/base.yaml

If you remove anything or let anything blank, it will just fall back to the standard configuration.
However, you will get warned.

Example:

use_standard_terminal_background: False

background_color:
  r: 31  # Red value
  g: 29  # Green value
  b: 67  # Blue value
  
...

2.2 Configure your secrets in: ~/.config/twidgets/secrets.env

Example:

WEATHER_API_KEY='your_api_key'
WEATHER_CITY='Berlin,DE'
WEATHER_UNITS='metric'
NEWS_FEED_URL='https://feeds.bbci.co.uk/news/rss.xml?edition=uk'
NEWS_FEED_NAME='BCC'

2.3 Adjust widgets and layouts in: ~/.config/twidgets/widgets/*.yaml

Example:

name: 'clock'
title: '  Clock'
enabled: True
interval: 1
height: 5
width: 30
y: 4
x: 87

weekday_format: '%A'  # day of the week
date_format: '%d.%m.%Y'  # us: '%m.%d.%Y', international: '%Y-%m-%d'
time_format: '%H:%M:%S'  # time

For full documentation see [Configuration Guide] (https://github.com/IceWizard7/terminal-widgets/blob/main/docs/configuration_guide.md)


3. Adding new widgets

Adding a new widget to terminal-widgets is very easy—just create two files! For a simple widget, that does not require heavy loading (no update function) you only need to define a configuration and a single Python function.

3.1. ⚙️ Define Configuration (.yaml)

Create the configuration file at ~/.config/twidgets/widgets/custom.yaml and set interval = 0 for simple widgets:

name: custom
title: My Custom Widget
enabled: true
interval: 0 # For simple content
height: 7
width: 30
y: 1
x: 1

3.2. 🐍 Write the Widget Logic (.py)

Note: Make sure to name the .yaml and .py files the same way (excluding suffixes)

Create the widget's Python file at ~/.config/twidgets/py_widgets/custom_widget.py

For a simple widget, you primarily need to define the draw function and use add_widget_content

Example:

from twidgets.core.base import Widget, draw_widget, add_widget_content, Config, UIState, BaseConfig
import typing

# 1. Define the draw function for content
def draw(widget: Widget, ui_state: UIState, base_config: BaseConfig) -> None:
    # Initialize the widget title, borders, etc.
    draw_widget(widget, ui_state, base_config)

    # Add your content (list of strings)
    content: list[str] = [
        'Welcome to my new widget!',
        'This is a test.',
        'It was very easy to create.'
    ]
    add_widget_content(widget, content)

# 2. Define the build function
def build(stdscr: CursesWindowType, config: Config) -> Widget:
    return Widget(
        config.name, config.title, config, draw, config.interval, config.dimensions, stdscr,
        update_func=None,
        mouse_click_func=None,
        keyboard_func=None,
        init_func=None
    )

For full documentation see Widget Guide


🧩 4. Contributing

Help the project grow: create an issue or pull request!


📜 5. License

See 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

twidgets-1.1.10.tar.gz (30.0 kB view details)

Uploaded Source

Built Distribution

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

twidgets-1.1.10-py3-none-any.whl (35.6 kB view details)

Uploaded Python 3

File details

Details for the file twidgets-1.1.10.tar.gz.

File metadata

  • Download URL: twidgets-1.1.10.tar.gz
  • Upload date:
  • Size: 30.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for twidgets-1.1.10.tar.gz
Algorithm Hash digest
SHA256 ab6730e942ee4c0f18946427d6cf7e99145cd4be8dd52e00f4346dfe2845ebfa
MD5 de6c054301f502f9b9f744d521134bef
BLAKE2b-256 ec8723733c1d199f0bc6d6526b9865efd1bc05ec9f6a83188d6c7db2f79e446f

See more details on using hashes here.

Provenance

The following attestation bundles were made for twidgets-1.1.10.tar.gz:

Publisher: publish.yml on IceWizard7/terminal-widgets

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

File details

Details for the file twidgets-1.1.10-py3-none-any.whl.

File metadata

  • Download URL: twidgets-1.1.10-py3-none-any.whl
  • Upload date:
  • Size: 35.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for twidgets-1.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 4a257bd19c029020e1f0ac90e170b305724e25cde0fce7c2c2a30b34dc4947c8
MD5 3c29e9db723df65efc443d5eb8489232
BLAKE2b-256 fa3b8f4df421d8d34dc0103af3990a18d8dc5ca1978240504544a67f2a2234f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for twidgets-1.1.10-py3-none-any.whl:

Publisher: publish.yml on IceWizard7/terminal-widgets

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