Skip to main content

Reusable PyQt UI toolkit primitives for SLI desktop tools.

Project description

SLI UI Toolkit

Reusable PyQt6 widgets and UI infrastructure for compact desktop tools.

SLI stands for Shared Lightweight Interface. The toolkit was extracted from Improve-ImgSLI and Tkonverter, but host-specific icons, translations, resources, and business logic stay outside the library.

What Is Included

  • custom-painted compact controls: buttons, inputs, switches, sliders, labels;
  • a unified Button system with icons, text, toggle, scroll, menu, long-press, ripple, and multi-region split layouts;
  • reusable composite widgets: flyouts, dialog shells, markdown help, timelines, toasts, lists, charts;
  • theme-aware painting through ThemeManager tokens;
  • app-injected hooks for icons, i18n, overlay placement, and timing.

Install

For development from this repository:

python -m venv .venv
source .venv/bin/activate
python -m pip install -U pip
python -m pip install -e ".[dev]"

For use as a dependency:

python -m pip install sli-ui-toolkit

Run The Demo

From the repository root:

python -m demo

The demo opens a PyQt window with widget pages for buttons, inputs, lists, dialogs, flyouts, charts, feedback, and miscellaneous primitives.

If you run on a headless machine, set Qt's platform first:

QT_QPA_PLATFORM=offscreen python -m demo

Run Tests

pytest tests/

The test suite uses pytest-qt and defaults to offscreen Qt through tests/conftest.py.

Basic Use

Most application code should import from sli_ui_toolkit.widgets.

from PyQt6.QtWidgets import QApplication, QVBoxLayout, QWidget

from sli_ui_toolkit.theme import ThemeManager
from sli_ui_toolkit.widgets import Button, ComboBox

app = QApplication([])

theme = ThemeManager.get_instance()
theme.set_theme("light", app)

window = QWidget()
layout = QVBoxLayout(window)

save = Button("save", text="Save", variant="surface")
mode = ComboBox()
mode.addItems(["Fast", "Balanced", "Quality"])

layout.addWidget(save)
layout.addWidget(mode)
window.show()

app.exec()

App Configuration Hooks

Hosts can inject app-specific behavior at startup:

  • configure_icon_resolver(...) Supplies icon lookup for app icon enums, names, or resources.
  • configure_toolkit(...) Supplies overlay placement and timing defaults for flyouts and popups.
  • configure_i18n(...) Supplies translation roots and language handling.

Minimal apps can use bundled toolkit icons and skip these hooks. Larger host apps should configure them once during startup.

Public Import Layers

  • sli_ui_toolkit Bootstrap/configuration helpers and common primitives.
  • sli_ui_toolkit.widgets Main public widget catalog. Prefer this for application UI.
  • sli_ui_toolkit.theme ThemeManager.
  • sli_ui_toolkit.icons Icon resolver configuration.
  • sli_ui_toolkit.i18n Translation manager and helpers.
  • sli_ui_toolkit.managers Flyout and timer helpers.
  • sli_ui_toolkit.services Utility services such as prewarm helpers.

Everything under sli_ui_toolkit.ui... is implementation detail first. Use it inside toolkit internals, or only when no public export exists yet.

Documentation

Development Notes

  • Keep host-app behavior outside the toolkit. Pass behavior through callbacks, signals, configuration hooks, or plain data objects.
  • Resolve colors and sizes through ThemeManager, widget properties, or documented tokens.
  • Update docs when changing public widget behavior or public API.
  • Run pytest tests/ before publishing or tagging a release.

Caveats

  • ComboBox is custom-painted; it is not a full QComboBox drop-in replacement.
  • The toolkit is designed around custom-painted controls, not QSS-skinned stock widgets.
  • Light and dark themes are both first-class. Avoid hard-coded colors in custom widgets; use theme tokens.

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

sli_ui_toolkit-0.2.14.tar.gz (233.7 kB view details)

Uploaded Source

Built Distribution

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

sli_ui_toolkit-0.2.14-py3-none-any.whl (271.7 kB view details)

Uploaded Python 3

File details

Details for the file sli_ui_toolkit-0.2.14.tar.gz.

File metadata

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

File hashes

Hashes for sli_ui_toolkit-0.2.14.tar.gz
Algorithm Hash digest
SHA256 f63a755a55925f0b38a94683a9d145865026929a907d05002739a0e4bbb157af
MD5 e9cbe92dfb192491cb4c037b33d9ed02
BLAKE2b-256 f1d49e4472d40845011c51017590e313629055a5fd9efafcea6b28719d27d9db

See more details on using hashes here.

Provenance

The following attestation bundles were made for sli_ui_toolkit-0.2.14.tar.gz:

Publisher: publish.yml on Loganavter/sli-ui-toolkit

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

File details

Details for the file sli_ui_toolkit-0.2.14-py3-none-any.whl.

File metadata

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

File hashes

Hashes for sli_ui_toolkit-0.2.14-py3-none-any.whl
Algorithm Hash digest
SHA256 4b6782420d14b84250863ae162b29cb354e059a4177b544f38d989f82221a960
MD5 aee255d009f345add28a990f980d1a3b
BLAKE2b-256 864a0c8e861a53a06d0428df9cff50c27f3bf78c186b57c489002cf56813b36a

See more details on using hashes here.

Provenance

The following attestation bundles were made for sli_ui_toolkit-0.2.14-py3-none-any.whl:

Publisher: publish.yml on Loganavter/sli-ui-toolkit

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