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
1.4 KiB
1.4 KiB
ET-QUA-005: Historial Integrado de Vivienda
ID: ET-QUA-005 | Módulo: MAI-009
Schema
CREATE TABLE quality.housing_history (
id UUID PRIMARY KEY,
housing_id UUID,
event_type VARCHAR(50), -- 'inspection', 'nc', 'ticket', 'delivery'
event_date TIMESTAMPTZ,
title VARCHAR(200),
description TEXT,
severity VARCHAR(20),
status VARCHAR(50),
photos TEXT[],
responsible_user UUID,
metadata JSONB
);
CREATE INDEX idx_housing_history_housing ON quality.housing_history(housing_id, event_date DESC);
Backend Service
@Injectable()
export class HousingHistoryService {
async getTimeline(housingId: string, filters?: TimelineFilters): Promise<TimelineEvent[]> {
const qb = this.historyRepo.createQueryBuilder('h')
.where('h.housing_id = :housingId', { housingId })
.orderBy('h.event_date', 'DESC');
if (filters?.eventType) qb.andWhere('h.event_type = :type', { type: filters.eventType });
if (filters?.startDate) qb.andWhere('h.event_date >= :start', { start: filters.startDate });
return qb.getMany();
}
async exportPDF(housingId: string): Promise<Buffer> {
const timeline = await this.getTimeline(housingId);
const housing = await this.housingRepo.findOne(housingId);
// Generar PDF con timeline completa
return this.pdfService.generateHousingHistory({ housing, timeline });
}
}
Generado: 2025-11-20