OutfitKit Jinja macros — semantic HTML components on top of the OutfitKit CSS library.
Project description
OutfitKit
Librería CSS de componentes para aplicaciones web. ~260 bloques semánticos con prefijo ok-*, BEM-light, themeable vía CSS custom properties.
Cero JS obligatorio. Cero build pipeline para consumidores. Un solo <link> y listo.
Uso (consumidor solo CSS)
Producción (default, sin prefijo)
<link rel="stylesheet"
href="https://cdn.jsdelivr.net/gh/OutfitKit/outfitkit@latest/dist/outfitkit.min.css">
<button class="btn btn--primary">Continuar</button>
Clases cortas, sin ruido. Es lo recomendado para cualquier proyecto donde OutfitKit sea la única librería CSS de la página — Hub, Cloud, los módulos m_* del marketplace.
Producción (opcional, con prefijo ok-)
Solo necesario si OutfitKit convive con otra librería CSS que ya define .btn, .card, etc. (Bootstrap, Tailwind utilities, Daisy, un design system propio anterior). El bundle prefijado evita las colisiones:
<link rel="stylesheet"
href="https://cdn.jsdelivr.net/gh/OutfitKit/outfitkit@latest/dist/outfitkit.ok.min.css">
<button class="ok-btn ok-btn--primary">Continuar</button>
Ambos bundles comparten exactamente los mismos tokens (--ok-*), keyframes y animations. Lo único que cambia son los nombres de los selectores de clase.
Desarrollo — fuente sin minificar
Útil para inspeccionar reglas individuales en DevTools:
<link rel="stylesheet"
href="https://cdn.jsdelivr.net/gh/OutfitKit/outfitkit@main/css/outfitkit.css">
<button class="ok-btn ok-btn--primary">Continuar</button>
La fuente en css/ siempre lleva el prefijo ok- (es como editamos el repo). El bundle sin prefijo se genera solo en CI al taggear. Los navegadores modernos resuelven los @import directamente, sin bundling local.
Macros Jinja (opcional)
Si tu backend es Python con Jinja2 (FastAPI, Flask, Django+jinja2 backend), puedes consumir los componentes como macros:
pip install outfitkit # macros vanilla
pip install outfitkit[jinjax] # + sintaxis HTML-like <Button label="x" />
Las macros viven en showcase/ y se publican desde ahí a PyPI. Cualquier macro funciona con o sin JinjaX (formato dual-mode).
Setup mínimo (default, sin prefijo)
from jinja2 import Environment, FileSystemLoader
from outfitkit import TEMPLATES_DIR, register_globals, css_url
env = Environment(loader=FileSystemLoader(TEMPLATES_DIR))
register_globals(env) # establece ok_prefix = ""
# En tu base.html
# <link rel="stylesheet" href="{{ css }}">
ctx = {"css": css_url()} # → outfitkit.min.css (sin prefijo)
Resultado: {{ button("Save") }} → <button class="btn btn--primary">…</button>.
Cambiar a prefijo ok- (solo si lo necesitas)
register_globals(env, ok_prefix="ok-")
ctx = {"css": css_url(prefix="ok-")} # → outfitkit.ok.min.css
Resultado: {{ button("Save") }} → <button class="ok-btn ok-btn--primary">…</button>.
Regla de oro
El prefijo de las macros y el bundle CSS cargado tienen que coincidir. Como ambos se controlan desde dos líneas del setup, no es una preocupación recurrente — lo eliges una vez y olvidas.
¿El paquete pip install outfitkit trae el CSS?
No, y es intencional. El paquete pip trae solo:
- Las macros Jinja (
outfitkit/templates/ui/*.jinja) que se importan en tu app. - Helpers Python (
TEMPLATES_DIR,register_globals,css_url,theme_url) que devuelven rutas y URLs.
El CSS lo sirve jsDelivr (CDN externo, gratis, edge-cached globalmente). El helper css_url() te devuelve la URL ya construida — tu plantilla solo tiene que ponerla en un <link>:
<link rel="stylesheet" href="{{ css_url() }}">
Por qué separados:
- Versionado independiente: un fix de CSS no necesita bumpear PyPI. Solo retaggeas
vX.Y.Zy jsDelivr sirve la nueva versión al instante. - Sin tráfico duplicado: no servirías 540 KB de CSS desde tu propio backend en cada petición; jsDelivr lo hace gratis y con CDN global.
- Wheels Python no son ideales para assets estáticos: empaquetar el CSS dentro obligaría a
pip install --upgradecada vez que cambia.
¿Y si necesito servir el CSS desde mi propio backend? (offline / aislado)
Casos válidos: red privada sin internet, paranoia con CDN, o cumplimiento que prohíbe externos. Tres opciones:
Opción A — descargar el bundle a tu static/:
# Una vez, en tu deploy script:
curl -L -o static/css/outfitkit.min.css \
https://cdn.jsdelivr.net/gh/OutfitKit/outfitkit@v1.3.0/dist/outfitkit.min.css
Y sirvelo desde tu backend:
<link rel="stylesheet" href="/static/css/outfitkit.min.css">
Opción B — git submodule del repo CSS:
git submodule add https://github.com/OutfitKit/outfitkit vendor/outfitkit
Sirve vendor/outfitkit/dist/outfitkit.min.css desde tu backend. git submodule update --remote cuando quieras pullear cambios.
Opción C — copiar las fuentes y bundlear tú mismo:
git clone --depth 1 https://github.com/OutfitKit/outfitkit
# Copia css/ a tu repo, ejecuta tu propio bundler.
Útil solo si vas a forkearlo o necesitas modificar tokens. Para uso normal, sobra.
Importante: sea cual sea la opción, el helper css_url() siempre apunta a jsDelivr. Si self-hosteas, no uses css_url() — pasa la URL de tu static directamente.
Sitio de demos
Componentes en vivo con código fuente al lado, navegable: https://outfitkit.github.io/outfitkit/
Estructura del repositorio
outfitkit/
├── css/ ← fuentes CSS sin minificar (lo que editas)
│ ├── tokens.css ← variables --ok-* (paleta, spacing, themes)
│ ├── base.css ← reset + tipografía
│ ├── utilities.css ← .ok-flex, .ok-gap-*, .ok-text-*
│ ├── outfitkit.css ← entry point con @import de todo
│ └── components/ ← 44 archivos, uno por familia (button, card, modal, ...)
├── dist/ ← bundles generados SOLO en CI al taggear (no editar a mano)
│ ├── outfitkit.css (concatenado, sin prefijo — default)
│ ├── outfitkit.min.css (minificado, sin prefijo — default)
│ ├── outfitkit.ok.css (concatenado, prefijo ok- — opt-in)
│ └── outfitkit.ok.min.css (minificado, prefijo ok- — opt-in)
└── showcase/ ← macros Jinja + sitio de demos + paquete PyPI
Contribuir
Editar CSS
Edita los archivos en css/. Para previsualizar tus cambios:
<link rel="stylesheet" href="./css/outfitkit.css">
cargado desde un servidor local cualquiera (python3 -m http.server 8000). No hay build local. Cuando estés contento, push y abre PR.
Releases
El bundle minificado lo genera la Action css-build.yml al taggear:
git tag v3.0.0
git push origin v3.0.0
La Action concatena css/*.css, minifica con lightningcss-cli y commitea dist/outfitkit.{css,min.css} al tag. jsDelivr sirve @v3.0.0/dist/outfitkit.min.css y @latest automáticamente.
Convenciones
Naming (BEM-light)
.ok-{block} base .ok-card
.ok-{block}__{element} child element .ok-card__header
.ok-{block}--{modifier} variant .ok-btn--primary
.is-{state} runtime state .is-active, .is-open
Theming
Themes se aplican vía atributo data-theme en <html> o cualquier subárbol:
<html data-theme="erplora"> <!-- default, dark terracota -->
<html data-theme="dark">
<html data-theme="light">
Cualquier variable --ok-* puede sobreescribirse para crear tu propio theme.
Licencia
MIT.
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 outfitkit-1.5.0.tar.gz.
File metadata
- Download URL: outfitkit-1.5.0.tar.gz
- Upload date:
- Size: 21.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1e4fdb24cc6fb7d2db85d06f23b2ad804fa29d35492e39983d6ada0458a074e9
|
|
| MD5 |
287764ed0a4c927ec8c1d9d8a29daa6a
|
|
| BLAKE2b-256 |
1457d27d56558182f5144cf9d3a8cb78e221a80f49a3b97f03360a624d33dbce
|
Provenance
The following attestation bundles were made for outfitkit-1.5.0.tar.gz:
Publisher:
pypi-publish.yml on OutfitKit/outfitkit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
outfitkit-1.5.0.tar.gz -
Subject digest:
1e4fdb24cc6fb7d2db85d06f23b2ad804fa29d35492e39983d6ada0458a074e9 - Sigstore transparency entry: 1498866188
- Sigstore integration time:
-
Permalink:
OutfitKit/outfitkit@7a8f7080abeaa15db5e1b44708034fc4388ae3fc -
Branch / Tag:
refs/tags/pypi-v1.5.0 - Owner: https://github.com/OutfitKit
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@7a8f7080abeaa15db5e1b44708034fc4388ae3fc -
Trigger Event:
push
-
Statement type:
File details
Details for the file outfitkit-1.5.0-py3-none-any.whl.
File metadata
- Download URL: outfitkit-1.5.0-py3-none-any.whl
- Upload date:
- Size: 49.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0b1fa768ec4cbead6996a6db87e63dcf37859f3119e96bc0ebdcc6aafdceda61
|
|
| MD5 |
ea67d33e0f99352898fccc784b598010
|
|
| BLAKE2b-256 |
6c69461f6ea333680a31ba194de71b41a3674258b55ee988e652167dd3c3fc98
|
Provenance
The following attestation bundles were made for outfitkit-1.5.0-py3-none-any.whl:
Publisher:
pypi-publish.yml on OutfitKit/outfitkit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
outfitkit-1.5.0-py3-none-any.whl -
Subject digest:
0b1fa768ec4cbead6996a6db87e63dcf37859f3119e96bc0ebdcc6aafdceda61 - Sigstore transparency entry: 1498866443
- Sigstore integration time:
-
Permalink:
OutfitKit/outfitkit@7a8f7080abeaa15db5e1b44708034fc4388ae3fc -
Branch / Tag:
refs/tags/pypi-v1.5.0 - Owner: https://github.com/OutfitKit
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@7a8f7080abeaa15db5e1b44708034fc4388ae3fc -
Trigger Event:
push
-
Statement type: