Skip to main content

From idea to a shipped desktop app, fast — a declarative, reactive, batteries-included Python UI framework with 60+ widgets, semantic theming, and built-in packaging.

Project description

bootstack

Downloads Downloads

Pre-release. The API may still change before 1.0. Full documentation is at bootstack.org.

From idea to a shipped desktop app — fast.

bootstack gives engineers, data scientists, and hobbyists everything to build a polished desktop interface and package it into a standalone executable — declarative, reactive, and batteries-included, all in pure Python.

bootstack hero demo

Why bootstack?

Most Python desktop frameworks make you fight the framework. bootstack gets out of the way.

  • 30% less code — the declarative, context-manager layout eliminates geometry calls, explicit parenting, and most of the wiring boilerplate
  • Reads like Python — nested with blocks mirror your UI structure; the code hierarchy is the layout
  • Modern layout systemHStack, VStack, and Grid containers handle spacing, alignment, and fill automatically; CSS conventions (gap, padding, margin, fill, anchor) without writing CSS
  • 60+ widgets out of the box — primitives through full composites: tables, trees, calendars, date pickers, gauges, sliders, and more — including a full CodeEditor with syntax highlighting, line numbers, bracket matching, smart indent, and search; no external editor dependency required
  • Reactive signals — observable state that flows between widgets; bind once, update everywhere
  • Event and stream pipelines — compose, filter, debounce, and throttle UI events with a chainable stream API
  • Built-in icons — the full Bootstrap Icons catalog, theme-aware and DPI-scaled, bundled with the framework
  • Built-in localization — 23 language catalogs, locale-aware number/date/time formatting, runtime language switching
  • Semantic stylingaccent="primary", variant="outline" — no hard-coded colors; looks right across every theme automatically
  • 8 paired light/dark themes — with a runtime switcher and a custom-theme API
  • Forms and validation — field-level validators, inline error messages, and a FormDialog for quick modal forms
  • DataSource abstraction — one interface over SQLite, in-memory, and file backends with filtering, sorting, pagination, and CRUD
  • A real CLI — scaffold, run, add pages/views/dialogs/themes, and package for distribution
  • PyInstaller packaging built inbootstack build produces a standalone executable; no separate toolchain required

Installation

Requires Python 3.12+ and Tk/Tcl (bundled with most Python distributions). bootstack is in pre-release, so opt in with --pre:

python -m pip install --pre bootstack

See the installation guide for platform-specific Tk setup and the optional data-format extras.

See it

The widget gallery is a single-window tour of everything bootstack ships — every widget, theme switcher, accent variants, and layout containers. Fastest way to see the framework in action without writing a line of code:

bootstack gallery
bootstack widget gallery

Quick Start

import bootstack as bs

with bs.App(title="Hello", padding=16, gap=16) as app:
    bs.Label("Hello from bootstack!")
    bs.Button("Primary", accent="primary")
    bs.Button("Success", accent="success")
    bs.Button("Danger Outline", accent="danger", variant="outline")

app.run()
bootstack quick start example

For navigation-based apps, use AppShell — it gives you a command bar, sidebar, and page stack in one call:

import bootstack as bs

shell = bs.AppShell(title="My App", size=(1000, 650))

with shell.add_page("home", text="Home", icon="house"):
    bs.Label("Welcome!")

with shell.add_page("docs", text="Documents", icon="file-earmark-text"):
    bs.Label("Your documents.")

shell.run()

How it works

Layout containers

VStack, HStack, and Grid let you describe a layout once instead of repeating geometry calls on each child:

with bs.App(title="Sign In") as app:
    with bs.Grid(columns=["auto", 1], gap=(12, 6), sticky_items="ew", padding=16):
        bs.Label("Name:")
        bs.TextField(placeholder="Full name")
        bs.Label("Email:")
        bs.TextField(placeholder="email@example.com")
        bs.Label("Role:")
        bs.Select(options=["Admin", "User", "Viewer"], value="User")
        bs.Button("Submit", accent="primary", columnspan=2)

app.run()
bootstack layout containers example

Semantic styling

Widgets take an accent (color intent) and variant (visual weight) instead of hard-coded colors, so the same code looks right across themes and light/dark modes:

bs.Button("Save", accent="primary")
bs.Button("Cancel", accent="secondary", variant="outline")
bs.Label("Heading", font="heading-lg")
bootstack semantic styling example

Signals (optional)

Plain callbacks work fine for most things. When state needs to flow between widgets, signals give you a small reactive primitive with two-way binding:

with bs.App(title="Hello") as app:
    name = bs.Signal("World")
    bs.Label(textsignal=name)      # updates automatically when name changes
    bs.TextField(textsignal=name)  # two-way binding to the same state

app.run()

Features

  • Application scaffoldingApp for blank windows, AppShell for command-bar + sidebar + page-stack apps, undecorated windows with custom chrome
  • 60+ themed widgets — primitives plus higher-level composites (DataTable, Tree, ListView, Calendar, DateField, Form, Gauge, ToggleGroup, PageStack, Carousel, Tooltip, and more)
  • Dialogs and messagesalert() / confirm() / ask_*() prompts and FormDialog / FontDialog / FilterDialog, plus non-blocking toast(), Notification, and Snackbar surfaces
  • Layout containersVStack, HStack, and Grid for declarative layouts; Card, GroupBox, ScrollView, SplitView, Accordion, Expander
  • Design system — semantic accent colors (primary, secondary, success, danger, warning, info) and variant tokens (solid, outline, ghost), consistent across widgets
  • Built-in themes — paired light/dark variants (amber, aurora, bootstrap, classic, docs, forest, ocean, rose) with runtime theme switching and a custom-theme API
  • Reactive signals — observable state with subscribe/set, integrates with widgets via signal= / textsignal=
  • Forms & validationForm with built-in field-level validators and inline error messages
  • DataSource — common interface over in-memory, SQLite, and file backends, with pagination, filtering, sorting, CRUD, and CSV/TSV/Excel export
  • Localization (i18n) — 23 bundled message catalogs, locale-aware number/date/time formatting via Babel, runtime language switching
  • Icons & images — Bootstrap Icons catalog with theme-aware recoloring, DPI scaling, and caching
  • Platform support — DPI awareness, multi-monitor centering, mica/acrylic effects on Windows
  • CLI (bootstack) — project scaffolding, run, add components, theme/i18n setup, doctor, build/package

Widget Categories

Category Widgets
Actions Button, ButtonGroup, MenuButton, ContextMenu, CommandBar
Inputs TextField, PasswordField, PathField, NumberField, SpinnerField, Slider, RangeSlider, TextArea, CodeEditor, DateField, TimeField
Selection Checkbox, Switch, ToggleButton, Radio, RadioGroup, ToggleGroup, Select, SelectButton, Calendar
Data Display Label, Badge, ListView, Tree, DataTable, ProgressBar, Gauge
Media Avatar, Picture, Gallery, Carousel
Layout VStack, HStack, Grid, Card, GroupBox, SplitView, ScrollView, Accordion, Separator
Navigation AppShell, CommandBar, SideNav, StatusBar, Tabs, PageStack
Dialogs alert(), confirm(), ask_*() prompts, FormDialog, FontDialog, FilterDialog
Overlays toast(), Notification, Snackbar, Tooltip
Forms Form, with field-level validation

CLI

bootstack ships with an optional CLI for scaffolding, running, and packaging applications:

bootstack gallery                           # Launch the interactive widget gallery
bootstack icons                             # Browse the built-in icon catalog
bootstack start MyApp                       # Create a new project (basic template)
bootstack start MyApp --template appshell   # ...or with sidebar navigation
bootstack run                               # Run the app defined in the project config
bootstack add page Dashboard                # Add a new page (appshell)
bootstack add view Settings                 # Add a new view (basic)
bootstack add dialog Preferences            # Add a new dialog
bootstack add i18n --languages en es fr     # Add i18n support
bootstack doctor                            # Diagnose project & environment
bootstack build                             # Package for distribution

Documentation

Full documentation — guides, the widget catalog, and the API reference — lives at bootstack.org.

Links

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

bootstack-0.1.0a10.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

bootstack-0.1.0a10-py3-none-any.whl (1.5 MB view details)

Uploaded Python 3

File details

Details for the file bootstack-0.1.0a10.tar.gz.

File metadata

  • Download URL: bootstack-0.1.0a10.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bootstack-0.1.0a10.tar.gz
Algorithm Hash digest
SHA256 6c1d4abe7f5482f7f8354e99cd24a64e77c10fa749a5868827a33057e346373b
MD5 97838c659b5477ef1087c408bafaa0f8
BLAKE2b-256 3836105d944c0357bebe55798128f97c7026751bec1e4df8f370934d29d3c6c2

See more details on using hashes here.

Provenance

The following attestation bundles were made for bootstack-0.1.0a10.tar.gz:

Publisher: release.yml on israel-dryer/bootstack

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

File details

Details for the file bootstack-0.1.0a10-py3-none-any.whl.

File metadata

  • Download URL: bootstack-0.1.0a10-py3-none-any.whl
  • Upload date:
  • Size: 1.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bootstack-0.1.0a10-py3-none-any.whl
Algorithm Hash digest
SHA256 22d068f552e3b406deb4668e63a94874b913c6943b547d38bc1a30c93c0d7f82
MD5 990e4548800a6169995d7f5570c20eb4
BLAKE2b-256 b6746148b9f3e13f9471acf25b8da504ecfac78f5196497d2534ead7f97447a4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bootstack-0.1.0a10-py3-none-any.whl:

Publisher: release.yml on israel-dryer/bootstack

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