workspace-v1/projects/erp-construccion/docs/97-adr/ADR-002-arquitectura-modular.md
rckrdmrd 66161b1566 feat: Workspace-v1 complete migration with NEXUS v3.4
Sistema NEXUS v3.4 migrado con:

Estructura principal:
- core/orchestration: Sistema SIMCO + CAPVED (27 directivas, 28 perfiles)
- core/catalog: Catalogo de funcionalidades reutilizables
- shared/knowledge-base: Base de conocimiento compartida
- devtools/scripts: Herramientas de desarrollo
- control-plane/registries: Control de servicios y CI/CD
- orchestration/: Configuracion de orquestacion de agentes

Proyectos incluidos (11):
- gamilit (submodule -> GitHub)
- trading-platform (OrbiquanTIA)
- erp-suite con 5 verticales:
  - erp-core, construccion, vidrio-templado
  - mecanicas-diesel, retail, clinicas
- betting-analytics
- inmobiliaria-analytics
- platform_marketing_content
- pos-micro, erp-basico

Configuracion:
- .gitignore completo para Node.js/Python/Docker
- gamilit como submodule (git@github.com:rckrdmrd/gamilit-workspace.git)
- Sistema de puertos estandarizado (3005-3199)

Generated with NEXUS v3.4 Migration System
EPIC-010: Configuracion Git y Repositorios
2026-01-04 03:37:42 -06:00

100 lines
2.6 KiB
Markdown

# ADR-002: Arquitectura Modular Monorepo
**Estado:** Aceptada
**Fecha:** 2025-11-24
**Responsable:** Architecture-Analyst
**Proyecto:** ERP Construccion
## Contexto
Necesitamos organizar el codigo en una estructura escalable y mantenible que soporte:
- Multiples aplicaciones (backend, frontend, mobile)
- Componentes compartidos con ERP Generico
- Modulos especificos de construccion
- Desarrollo en equipo
## Decision
**Monorepo con estructura:**
```
erp-construccion/
+-- apps/
| +-- database/ # DDL, seeds
| +-- backend/ # API REST
| +-- frontend/ # Web app
| +-- mobile/ # React Native (asistencias)
+-- packages/ # Librerias compartidas
+-- docs/ # Documentacion
+-- devops/ # Scripts, CI/CD
```
**Dependencia de ERP Generico:**
```json
{
"dependencies": {
"@erp-generic/core": "^1.0.0",
"@erp-generic/financial": "^1.0.0",
"@erp-generic/purchasing": "^1.0.0",
"@erp-generic/ui-components": "^1.0.0"
}
}
```
## Justificacion
### Referencia a Gamilit
- Estructura probada en produccion
- Organizacion clara por aplicacion
- Facil navegacion y onboarding
### Alineacion con ERP Generico
- Misma estructura permite reutilizacion
- Modulos especificos se agregan sin conflicto
### Especifico para Construccion
- Modulo mobile separado para asistencias GPS
- Modulos especificos: proyectos-obra, estimaciones, INFONAVIT
## Consecuencias
### Positivas
- Escalabilidad (agregar nuevas apps)
- Reutilizacion de codigo (packages compartidos + ERP Generico)
- Desarrollo en equipo sin conflictos
- Testing aislado por app
- 61% de reutilizacion del ERP Generico
### Negativas
- Complejidad inicial de setup
- Requiere herramientas monorepo (npm workspaces)
- Gestion de versiones con ERP Generico
## Alternativas Consideradas
**1. Repositorios separados**
- Rechazada: Dificulta sincronizacion con ERP Generico
**2. Monolito unico**
- Rechazada: No escalable, no permite reutilizacion
**3. Fork del ERP Generico**
- Rechazada: Perdemos actualizaciones automaticas
## Implementacion
### Acciones Requeridas
- [x] Crear estructura de carpetas
- [x] Configurar npm workspaces
- [x] Setup path aliases
- [ ] Configurar dependencias de ERP Generico
### Criterios de Aceptacion
- Apps pueden importar packages compartidos
- Apps pueden importar modulos de ERP Generico
- Build independiente por app funcional
- Modulos especificos no afectan al generico
## Referencias
- [ERP Generico ADR-002](../../erp-generic/docs/adr/ADR-002-arquitectura-modular.md)
- [Gamilit Backend Patterns](../../shared/reference/gamilit/backend-patterns.md)