workspace-v1/projects/erp-construccion/docs/02-definicion-modulos/MAE-016-gestion-documental/especificaciones/ET-DOC-005-workflow de aprobación.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

1.3 KiB

ET-DOC-005: Workflow de Aprobación

ID: ET-DOC-005 | Módulo: MAE-016

Approval Workflow Service

@Injectable()
export class ApprovalWorkflowService {
  async initiateApproval(documentId: string, workflowId: string): Promise<void> {
    const workflow = await this.workflowRepo.findOne(workflowId);
    const document = await this.documentRepo.findOne(documentId);
    
    for (const step of workflow.steps) {
      await this.approvalRepo.save({
        documentId,
        approverRole: step.role,
        order: step.order,
        status: 'pending',
        deadline: this.addDays(new Date(), step.deadlineDays)
      });
    }
    
    await this.notifyNextApprover(documentId);
  }

  async approve(approvalId: string, userId: string, comments?: string): Promise<void> {
    const approval = await this.approvalRepo.findOne(approvalId);
    approval.status = 'approved';
    approval.approvedBy = userId;
    approval.approvedAt = new Date();
    approval.comments = comments;
    await this.approvalRepo.save(approval);
    
    const hasNext = await this.hasNextApprover(approval.documentId);
    
    if (hasNext) {
      await this.notifyNextApprover(approval.documentId);
    } else {
      await this.finalizeApproval(approval.documentId);
    }
  }
}

Generado: 2025-11-21