workspace-v1/projects/erp-construccion/docs/02-definicion-modulos/MAE-014-finanzas-controlling/especificaciones/ET-FIN-003-servicio de facturació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

990 B

ET-FIN-003: Servicio de Facturación

ID: ET-FIN-003 | Módulo: MAE-014

Invoice Service

@Injectable()
export class InvoiceService {
  async createFromEstimation(estimationId: string): Promise<Invoice> {
    const estimation = await this.estimationService.findOne(estimationId);
    
    const invoice = await this.invoiceRepo.save({
      projectId: estimation.projectId,
      clientId: estimation.clientId,
      amount: estimation.montoNeto,
      concept: `Estimación ${estimation.numero}`,
      dueDate: this.calculateDueDate(estimation)
    });
    
    await this.cfdiService.stamp(invoice); // Timbrado SAT
    return invoice;
  }

  async applyPayment(invoiceId: string, amount: number): Promise<void> {
    const invoice = await this.findOne(invoiceId);
    invoice.paidAmount += amount;
    invoice.status = invoice.paidAmount >= invoice.amount ? 'paid' : 'partial';
    await this.invoiceRepo.save(invoice);
  }
}

Generado: 2025-11-21