Backlog v3.3
Derivado de 63 fricciones registradas al construir 6 pantallas reales (CRM, ajustes, checkout,
ERP denso, formulario móvil, dashboard del cluster) consumiendo el sistema como un adoptante.
Origen: stress sintético (agentes, no usuarios humanos) — pero los huecos hallados son reales.
Detalle por pantalla en docs/fricciones-stress/*.md.
Hallazgo central
El sistema está más especificado que implementado: el catálogo §8 describe 20 componentes,
pero @meridiano/componentes empaqueta 8. Cada pantalla tuvo que reconstruir a mano lo que el
documento ya promete. La brecha no es de diseño — es de implementación. Cerrarla sube D3
(componentes) de forma decisiva.
Convergencia (fricciones que aparecieron en 2+ pantallas)
| Hueco | Pantallas que lo sufrieron | Sección que ya lo especifica | Severidad |
|---|---|---|---|
m-tabla (orden, selección, paginación, zebra, densidad) |
CRM, ERP, dashboard | §8.5 | Alta |
m-select / m-radio / m-checkbox (con estado indeterminado) |
CRM, ajustes, ERP | §8.3, §8.4 | Alta |
m-pasos / stepper de progreso |
checkout, móvil | §9.5 | Alta |
Componentes de app shell (m-barra-lateral, m-barra-superior) |
CRM, ajustes, ERP, dashboard | §12.1 | Alta |
m-tabs / control segmentado |
ajustes | §8.7 | Alta |
m-banner (error a nivel de página, distinto del toast) |
checkout | §9.3 | Alta |
m-progreso / medidor (barra con umbrales) |
dashboard, móvil | §8.14 | Alta |
| Barras horizontales y >6 series en el gráfico (rankings) | dashboard, ERP | §10.2 | Media |
| Dona con más de 5 porciones reales o ranking alternativo | dashboard | §10.2 | Media |
m-switch con etiqueta externa (aria-labelledby) |
dashboard | §8.4 | Media |
API de validación en m-campo (+ textarea, inputmode, autocomplete) |
todas las de formulario | §8.2, §8.16 | Media |
Densidad en los componentes, no solo en CSS (m-switch, m-badge, KPI, gráficos no compactan) |
ERP, móvil | §7.8 | Media |
m-fab / barra de acción inferior |
móvil | §8.18 | Media |
m-chip removible para filtros |
ERP | §9.7 | Media |
m-avatar |
CRM | §8.15 | Baja |
m-modal ancho 640 para formularios (hoy fijo 480) |
CRM | §8.8 | Baja |
Fricciones de documentación (no de código)
- Token terciario como texto pequeño: 3 pantallas (CRM, checkout, móvil) lo eligieron y falló APCA. El sistema ya lo dice (§7.1: "solo texto grande o decorativo") pero no es evidente desde el nombre. → Añadir aviso en la doc del token y, mejor, exponer
texto-terciariocon scope restringido. - Objetivo táctil 44px vs
--control40px: en móvil los componentes quedan bajo el mínimo WCAG 2.5.8. → Regla: en móvil forzar densidad espaciosa omin-height: 44pxen los componentes interactivos.
Lo que funcionó sin fricción (madurez confirmada)
- Tokens y tema oscuro: re-mapeo semántico impecable en las 6 pantallas.
m-botoncon estadocargando/aria-busy: encajó directo en "Procesando pago…".m-modal: foco atrapado, Escape y retorno verificados en CRM, checkout y ajustes.m-toastcon "Deshacer",m-badge(APCA validado),m-switch(eventocambio= guardado inmediato).- La regla global
:focus-visiblede los tokens cubrió incluso los controles improvisados. - axe: 0 violaciones serias/críticas en las 6 pantallas, en claro y oscuro — los contrastes que aparecieron eran del consumidor eligiendo mal el token, no del sistema.
Plan de cierre (próxima versión)
- v3.3 — Implementar la brecha §8: ✅ HECHO —
m-tabla,m-select,m-radio,m-checkbox,m-tabs,m-pasos,m-banner,m-progresoimplementados con pruebas axe en verde (@meridiano/componentes@0.2.0). - v3.3 — Componentes de layout: ✅ HECHO —
m-barra-lateral,m-barra-superior,m-fab(§12, §8.18). - v3.2.x — Endurecer lo existente: pendiente — densidad real en componentes,
min-heighttáctil en móvil, API de validación dem-campo, ancho de modal por variante. - Doc: pendiente — aviso en token terciario; regla táctil móvil en §15.
Estado tras v3.3
De los 12 huecos convergentes de alta/media severidad, 10 quedan cubiertos por los nuevos componentes. Restan los de endurecimiento (punto 3) y documentación (punto 4) para una v3.3.x. La brecha "especificado vs implementado" pasó de 8/20 a 19/20 componentes del §8 empaquetados.
Control de cambios
| Versión | Fecha | Autor | Descripción del cambio |
|---|---|---|---|
| 1.0 | 2026-06-13 | Andrés García | Backlog derivado de 51 fricciones del motor de madurez (6 pantallas) |