FastBlocks UI: HTML/CSS-first styling and component helpers for FastBlocks, successor to archived fastbulma
Project description
FastBlocks UI
FastBlocks UI is a modern HTML/CSS-first UI layer with a stable ui-* namespace, Jinja/FastBlocks helpers, and optional enhancement JavaScript. It is the successor to the archived fastbulma project and is built as a clean-slate system with no compatibility bridge and no Sass/build-tool requirement.
Features
- HTML/CSS First: Uses semantic markup, CSS variables, and cascade layers as the foundation
- Template Helpers: Ships Python helpers for Jinja, async Jinja, and FastBlocks rendering
- htmx Safe: Keeps IDs, form fields, and interaction state in normal light DOM markup
- Optional Enhancement JS: Keeps behavior light and progressive-enhancement friendly
- Modern Styling: Uses a Tailwind-inspired semantic token baseline with custom visuals
- Permissive License: BSD-3-Clause for commercial and open-source use
Component Model
FastBlocks UI components are standard HTML patterns with ui-* classes and
helper-backed server rendering. The v1 runtime does not register Custom Elements
and does not use shadow DOM by default. htmx targets, triggers, and swapped
regions should remain normal light DOM nodes so the server stays authoritative
for selected tabs, open menus, form state, and validation state.
Optional light-DOM Custom Elements such as <ui-tabs>, <ui-dialog>, and
<ui-menu> are available as opt-in wrappers around the canonical helper output
and are tracked in docs/light-dom-custom-elements-spec.md.
Installation
Install using pip:
pip install fastblocks-ui
Then copy the assets to your project:
fastblocks-ui copy-assets --dest ./static
Usage
Once installed, you can use the ui-* classes and Python helpers with server-rendered HTML:
<div class="ui-card">
<div class="ui-card__header">Card Title</div>
<div class="ui-card__body">
This is a FastBlocks UI card styled with semantic tokens.
</div>
<footer class="ui-card__footer">
<button class="ui-button is-primary" type="button">Action</button>
</footer>
</div>
For full examples covering sync Jinja, async Jinja, and htmx fragments, see docs/usage.md. The component manifest is documented in docs/components.md. PWA-friendly app integration notes live in docs/pwa.md. Theming recipes live in docs/theming-recipes.md.
Template Examples
Sync Jinja
{{ button("Save changes", variant="primary", type="submit") }}
Async Jinja
template = env.get_template("profile.html")
html = await template.render_async(user=user, button=button)
htmx Fragment
<form id="profile-form" hx-post="/profile" hx-target="#profile-form" hx-swap="outerHTML">
{{ field(
label="Email address",
control_html=ui_input(id="profile-email", name="email", type="email", value=user.email)
) }}
{{ button("Save", variant="primary", type="submit") }}
</form>
Theming
FastBlocks UI enables flexible theming through CSS variables:
:root {
--ui-color-primary: #e040fb;
--ui-radius-md: 8px;
--ui-color-success: #00c853;
}
FastBlocks UI components automatically inherit these changes through semantic token mapping.
Components
FastBlocks UI centers its public surface on ui-* classes and helper APIs:
Layout Components
ui-container/container()- Centered max-width containerui-columns/columns()- 12-column responsive gridui-column/column()- Individual column in gridui-section/section()- Vertical spacing containerui-footer/footer()- Page footerui-level/level()- Horizontal toolbar/navui-hero/hero()- Full-width banner sectionui-title/title()- Typography titleui-media/media()- Image + text pairui-tile/tile()- Hierarchical tile layout
UI Components
ui-button/button()- Buttonsui-card/card()- Cardsui-field/field()- Form groupsui-input/input()- Form inputsui-select/select()- Select dropdownsui-checkbox/checkbox()- Checkboxesui-switch/switch()- Toggle switchesui-dialog/dialog()- Modal dialogsui-tabs/tabs()- Tabbed interfacesui-menu/menu()- Menusui-alert/alert()- Alerts
License
BSD-3-Clause
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fastblocks_ui-0.5.0.tar.gz.
File metadata
- Download URL: fastblocks_ui-0.5.0.tar.gz
- Upload date:
- Size: 31.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd6752fce1c355c69d871305485790f8953f92c1952884a00c9e8453849ea294
|
|
| MD5 |
68b8208cd5647ad3c8ac3c01cad1ffae
|
|
| BLAKE2b-256 |
b741b8a58e99940bef4d13cfa1efabff2a58569cafcc9b657cdc6cf113091b91
|
File details
Details for the file fastblocks_ui-0.5.0-py3-none-any.whl.
File metadata
- Download URL: fastblocks_ui-0.5.0-py3-none-any.whl
- Upload date:
- Size: 33.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fb744ea34ad5b239e9332801bfdff3d62f48e6edc9db60d053d1286433e57f43
|
|
| MD5 |
a4685bd62ffaf357d18bcea4fc609f44
|
|
| BLAKE2b-256 |
0f7b36972abc21f783ddcb48163f3bff50bff46ee1fd3572ad6a914ba29359a0
|