- Create TASK-2026-01-25-NOTIFICACIONES-COMPLETAS with full CAPVED docs - Update DATABASE_INVENTORY with auth.notifications, auth.user_push_tokens, investment.distribution_history, investment.distribution_runs tables - Update BACKEND_INVENTORY with push-token endpoints, firebase.client, and unit tests - Update FRONTEND_INVENTORY with notification components, store, service - Update MASTER_INVENTORY with updated totals - Update _INDEX.yml with new task entry Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
1.7 KiB
1.7 KiB
03-PLANEACION - Sistema de Notificaciones Completo
Orden de Implementacion
Fase 1: DDL (4 archivos)
-
auth/tables/11-notifications.sql- Tabla principal de notificaciones
- Constraints para type, priority, icon_type
- Indices para user_id, created_at, unread
-
auth/tables/12-user_push_tokens.sql- Tokens FCM/APNs por usuario
- Constraint platform (web, ios, android)
- Indice partial para tokens activos
-
investment/tables/08-distribution_history.sql- Historial de distribuciones por cuenta
- Constraint unique (account_id, distribution_date)
- Constraint valid_balance_change
-
investment/tables/09-distribution_runs.sql- Logs de ejecucion del job
- Constraint valid_counts
- Indice por run_date DESC
Fase 2: Backend Push Notifications
- Instalar dependencias:
firebase-admin,web-push - Actualizar config/index.ts con firebase y webPush
- Crear firebase.client.ts con:
- sendToDevice()
- sendToMultiple()
- deactivateInvalidTokens()
- Actualizar notification.service.ts para usar firebaseClient
- Agregar endpoints push-token en controller y routes
Fase 3: Tests Unitarios
-
notification.service.spec.ts (~450 lineas)
- Mocks de db, wsManager, nodemailer, firebase
- Tests para cada metodo publico
-
distribution.job.spec.ts (~380 lineas)
- Mocks de db, notification service
- Tests para logica de distribucion
Fase 4: Frontend
- notification.service.ts - API client
- notificationStore.ts - Zustand con WebSocket
- NotificationBell.tsx - Icono con badge
- NotificationDropdown.tsx - Lista reciente
- NotificationItem.tsx - Item individual
- NotificationsPage.tsx - Pagina completa
- Actualizar MainLayout.tsx y App.tsx