4.8 KiB
Plan somero de cierre de rama — 25-10-18
Objetivo
- Cerrar esta rama asegurando funcionalidad clave, fiabilidad percibida y coherencia de UX, para mergear con main con confianza.
Criterios generales de “listo”
- No romper flujos existentes.
- Feedback claro en interacciones sin cambio visual evidente.
- Estado de UI estable (sin saltos de scroll ni pérdidas de colapso).
- Cobertura mínima en tests para los cambios críticos.
Bloque 1: Bloqueantes para merge (función y confianza)
-
Feeds de calendario (multiusuario) (Completada)
- Hipótesis: la UI no recibe token en no-admin o no refresca tras rotar; posible gating de backend por rol/sesión.
- Señales de listo:
- No-admin ve/usa su URL tras rotar; .ics responde 200 con contenido válido.
- Rotar invalida el token anterior (URL vieja deja de servir).
- Tests cubren 2 no-admin y 1 admin.
-
Copiar y Rotar (feedback) (Completada)
- Hipótesis: botones funcionan de forma intermitente y sin feedback; usar toasts existentes.
- Señales de listo:
- Copiar: “URL copiada” o “No se pudo copiar” según resultado.
- Rotar: “Feed de calendario rotado” y la UI actualiza la URL inmediatamente.
- Fallback si Clipboard falla.
-
Estado de colapso y scroll al completar tareas (Completada)
- Hipótesis: rerender global resetea colapso y reposiciona scroll.
- Señales de listo:
- Completar/descompletar no altera colapso ni posición de scroll.
- Colapso persiste por groupId (localStorage) y tras refresh.
-
Validación: no permitir tareas sin descripción
- Señales de listo:
- Front bloquea envío vacío con mensaje claro.
- API devuelve 400 con error entendible.
- Señales de listo:
-
Modo oscuro en página intermedia de acceso
- Señales de listo:
- Respeta prefers-color-scheme y/o preferencia guardada.
- Sin parpadeo ni estilos rotos.
- Señales de listo:
Bloque 2: Refinamientos UX de bajo riesgo
-
Mensajes para “clics silenciosos” (Completada)
- Criterio: usar toast solo cuando no hay cambio visible inmediato (copiar, rotar, acciones async).
- Señales de listo: catálogo simple de interacciones con su feedback (info/success/error).
-
Bloquear acciones alrededor durante edición
- Señales de listo:
- Estado “editing” deshabilita acciones peligrosas cercanas (aria-disabled).
- Salir de edición restaura interactividad sin perder foco ni contenido.
- Señales de listo:
-
Animaciones sutiles (colapsar/expandir) (Completada)
- Señales de listo:
- Transiciones 150–200 ms; respetar prefers-reduced-motion.
- Sin jank en listas largas.
- Señales de listo:
Bloque 3: Navegación y coherencia visual (mini exploración)
-
Unificar tabs entre desktop y mobile (top siempre)
- Idea: tabs arriba en ambos; mini barra superior con sesión y logout.
- Señales de listo:
- Variante elegida (wireframe simple).
- Tokens de densidad definidos (tipografía/espaciado) y patrón de iconografía coherente.
-
Personalidad y densidad
- Pistas rápidas:
- Tipografías y espaciado más compactos en listas.
- Uso consistente del color de grupo.
- Etiquetas concisas e iconos de apoyo.
- Señales de listo: 2 pantallas “antes/después” aprobadas, cambios acotados a tokens/variables.
- Pistas rápidas:
Bloque 4: Integridad de datos y ciclo de vida
-
Eliminación de grupo (Completada)
- Propuesta: borrado duro con ON DELETE CASCADE para tareas, asignaciones y tokens; invalidar feeds asociados.
- Señales de listo:
- Contrato decidido y documentado.
- Constraints y tests que demuestran que tareas y feeds desaparecen de UI y endpoints.
-
Crear tareas desde la web (post-merge, MVP)
- Alcance mínimo: descripción obligatoria, fecha opcional, grupo opcional, auto-asignación.
- Señales de listo: validaciones consistentes con el bot.
Riesgos y verificaciones rápidas
- Sesión/locals.userId inconsistentes en no-admin → verificar endpoints de rotar/listar tokens.
- Invalidez de tokens viejos tras rotar → asegurar revocación real y no solo visual.
- Re-renders que destruyen estado local → preservar claves de lista, actualizaciones puntuales.
Métricas y tests mínimos
- Tests web para: rotar token personal en no-admin (200 .ics), copiar con éxito (toast), completar tarea sin perder estado.
- Unit tests: validación de descripción en API.
- Smoke: modo oscuro en página intermedia.
Siguientes pasos inmediatos (quick wins)
- Añadir toasts a Copiar/Rotar y verificar copyToClipboard con fallback.
- Persistir colapso por groupId en localStorage y restaurar en montaje.
- Revisar flujo de tokens ICS con dos usuarios no-admin y un admin (rotar → validar .ics nuevo y caducidad del viejo).
Notas
- La navegación unificada y la “personalidad visual” se abordan después de merge si crecen en alcance.
- Priorizar siempre claridad y facilidad de uso sobre adorno; la forma sigue a la función.