sigo-entities 1.2.353 → 1.2.355

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,70 @@
1
+ # CLAUDE.md
2
+
3
+ Frontend: C:\Users\USER\Desktop\Michael\5_cobra\1_workspace\1_projects\SIGO\Frontend\sigo-frontend-2
4
+ Backend: C:\Users\USER\Desktop\Michael\5_cobra\1_workspace\1_projects\SIGO\Backend\sigo-backend
5
+ Sigo-entities: C:\Users\USER\Desktop\Michael\5_cobra\1_workspace\1_projects\SIGO\npm\sigo-entities
6
+
7
+ ## Descripción
8
+ Paquete NPM interno — contrato compartido de tipos, validación y transformación entre `sigo-frontend` y `sigo-backend`.
9
+
10
+ ## Comandos
11
+
12
+ ```bash
13
+ npm run build # Compila con tsup (CJS + ESM) y resuelve path aliases con tsc-alias
14
+ ```
15
+
16
+ ## Arquitectura
17
+
18
+ El paquete exporta todo desde `src/index.ts`, que re-exporta por dominio:
19
+
20
+ ```
21
+ src/
22
+ administracion/ — asistencia, personal, etc.
23
+ configuracion/ — usuarios, perfiles
24
+ logistica/ — bodega, items, almacen
25
+ operativa/ — mantenimientos, procesos
26
+ programados/ — tareas programadas
27
+ shared/ — DTOs, enums, types y utils reutilizables
28
+ v2/ — versión 2 de entidades/DTOs
29
+ ```
30
+
31
+ Cada dominio tiene su propio `index.ts` que agrega exports de sus submódulos. El entry point es `dist/index.js` (CJS) / `dist/index.mjs` (ESM) con tipos en `dist/index.d.ts`.
32
+
33
+ ## Patrón de entidades y DTOs
34
+
35
+ **ENTITY**: Representa un documento completo de una colección MongoDB.
36
+ **DTO**: Representa una sub-estructura reutilizable o forma de datos anidados.
37
+
38
+ Ejemplo de propiedad con el patrón completo:
39
+
40
+ ```ts
41
+ @Expose()
42
+ @IsDefined({ message: "El campo X es obligatorio" })
43
+ @IsString()
44
+ @Length(0, 75)
45
+ @Transform(({ value }) => value?.toUpperCase().trim())
46
+ Codigo: string = ''
47
+ ```
48
+
49
+ Patrones clave:
50
+
51
+ - Todas las propiedades se inicializan con valores por defecto (strings vacíos, `0`, `new Class()`)
52
+ - Objetos anidados usan `@Type(() => DtoClass)` + `@ValidateNested()`
53
+ - Arrays usan `@IsArray()` + `@ValidateNested({ each: true })`
54
+ - Texto normalmente se transforma con `.toUpperCase().trim()`
55
+
56
+ ## Path aliases (tsconfig)
57
+
58
+ ```json
59
+ "@shared-dto/*" → "src/shared/dto/*"
60
+ "@shared-types/*" → "src/shared/types/*"
61
+ "@shared-enums/*" → "src/shared/enums/*"
62
+ ```
63
+
64
+ ## Convenciones importantes
65
+
66
+ - Cada colección MongoDB tiene exactamente una `ENTITY`
67
+ - Naming: `[Nombre]ENTITY` y `[Nombre]DTO`
68
+ - Este paquete es la única fuente de verdad para los tipos — no duplicar en front ni back
69
+ - Cualquier cambio en una entidad impacta ambos proyectos — cuidado con breaking changes
70
+ - `reflect-metadata` se importa en el `src/index.ts` raíz (requerido por class-validator/transformer)
@@ -0,0 +1,21 @@
1
+ {
2
+ "allow": [
3
+ "Read(//c/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/Frontend/sigo-frontend-2/**)",
4
+ "Read(//c/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/Backend/sigo-backend/**)",
5
+ "Read(//c/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/npm/sigo-entities/**)",
6
+ "Read(//c/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/npm/sigo-package/**)",
7
+ "Read(.env)",
8
+ "Read(.env.*)"
9
+ ],
10
+ "env": {
11
+ "SIGO_FRONTEND": "C:/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/Frontend/sigo-frontend-2",
12
+ "SIGO_BACKEND": "C:/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/Backend/sigo-backend",
13
+ "SIGO_ENTITIES": "C:/Users/USER/Desktop/Michael/5_cobra/1_workspace/1_projects/SIGO/npm/sigo-entities"
14
+ },
15
+ "permissions": {
16
+ "deny": [
17
+ "Read(node_modules/**)",
18
+ "Read(dist/**)"
19
+ ]
20
+ }
21
+ }
@@ -0,0 +1,60 @@
1
+ ---
2
+ name: mdl-administracion
3
+ description: >
4
+ Dominio administracion/ — base de datos MDL_ADMINISTRACION. Usar cuando se trabaje con
5
+ órdenes de trabajo (OT), asistencia, mano de obra, precios, baremos, documentación PEX,
6
+ zonas de trabajo, o cualquier entidad/DTO dentro de src/administracion/.
7
+ ---
8
+
9
+ # Skill: MDL_ADMINISTRACION
10
+
11
+ Carpeta: `src/administracion/`
12
+ Base de datos MongoDB: **MDL_ADMINISTRACION**
13
+
14
+ También contiene parte de **MDL_CATALOGO** — datos de referencia como precios, tipos y unidades.
15
+
16
+ ## Sub-dominios principales
17
+
18
+ | Carpeta | Contenido |
19
+ |---|---|
20
+ | `ot/` | Órdenes de Trabajo — vigencia, estado |
21
+ | `otglobal/` | OT globales |
22
+ | `asistencia/` | Registro de asistencia y resumen |
23
+ | `mano-obra-unidad-obra/` | Relación mano de obra ↔ unidad de obra |
24
+ | `mano_obra_mtto/` | Mano de obra en mantenimiento |
25
+ | `precio-mano-obra/` | Precios de MO (global, empresa, precio actual) — **MDL_CATALOGO** |
26
+ | `precio material/` | Precios de materiales — **MDL_CATALOGO** |
27
+ | `precio especialidad/` | Precios por especialidad y agencia — **MDL_CATALOGO** |
28
+ | `unidad_obra/` | Catálogo de unidades de obra — **MDL_CATALOGO** |
29
+ | `unidad obra material/` | Materiales por unidad de obra — **MDL_CATALOGO** |
30
+ | `zona trabajo/` | Zonas de trabajo y contratos OT |
31
+ | `documentacion-pex/` | Documentación de procesos PEX |
32
+ | `documentacion-baremo-pex/` | Baremos para documentación PEX |
33
+ | `tipo movil/` | Tipos de vehículo/móvil — **MDL_CATALOGO** |
34
+ | `tipo_clave/` | Tipos de clave — **MDL_CATALOGO** |
35
+ | `rm_zona_actividad/` | Relación RM zona-actividad |
36
+ | `ItemExtra/` | Ítems extra (SKU, proveedor) |
37
+ | `EstadoInterno/` | Estados internos de OT |
38
+ | `permisos-app/` | Permisos de la app |
39
+ | `mail structure/` | Estructura de destinatarios de mail |
40
+ | `key integracion/` | Claves de integración externa |
41
+ | `PrecioAgencia_mam_onnet/` | Precios de agencia MAM/Onnet |
42
+ | `chile 9512 paquetizado mano obra/` | Chile: MO paquetizada contrato 9512 |
43
+ | `chile 9512 paquetizado material/` | Chile: material paquetizado contrato 9512 |
44
+
45
+ ## Naming
46
+
47
+ - Entidades: `[Nombre]ENTITY` — representan una colección MongoDB completa
48
+ - DTOs: `[Nombre]DTO` — sub-estructuras anidadas o reutilizables
49
+ - Ejemplo: `OtENTITY`, `VigenciaOtDTO`, `PrecioManoObraENTITY`, `PrecioEmpresaDTO`
50
+
51
+ ## Ubicación de archivos
52
+
53
+ ```
54
+ src/administracion/
55
+ └── [nombre-modulo]/
56
+ └── shared/
57
+ ├── [nombre].entity.ts ← ENTITY principal
58
+ └── dto/
59
+ └── [nombre]-dto.ts ← DTOs anidados
60
+ ```
@@ -0,0 +1,49 @@
1
+ ---
2
+ name: mdl-configuracion
3
+ description: >
4
+ Dominio configuracion/ — base de datos MDL_CONFIGURACION. Usar cuando se trabaje con
5
+ usuarios, perfiles, empresas, sistema, notificaciones, cargos, contratos OT,
6
+ o cualquier entidad/DTO dentro de src/configuracion/.
7
+ ---
8
+
9
+ # Skill: MDL_CONFIGURACION
10
+
11
+ Carpeta: `src/configuracion/`
12
+ Base de datos MongoDB: **MDL_CONFIGURACION**
13
+
14
+ ## Sub-dominios principales
15
+
16
+ | Carpeta | Contenido |
17
+ |---|---|
18
+ | `usuarios/` | Usuarios del sistema |
19
+ | `usuarios autoinventario/` | Usuarios del módulo autoinventario |
20
+ | `perfiles/` | Perfiles de acceso y sistemas asociados |
21
+ | `personal/` | Datos del personal |
22
+ | `cargo personal/` | Cargos/roles del personal |
23
+ | `empresa/` | Empresas (datos generales, GIA, grupo empresa, representante legal, tipo) |
24
+ | `sistema/` | Configuración general del sistema |
25
+ | `opcion sistema/` | Opciones del sistema |
26
+ | `tipo opcion sistema/` | Tipos de opciones del sistema |
27
+ | `tipo especialidad mo/` | Tipos de especialidad de mano de obra |
28
+ | `tipo clave/` | Tipos de clave de configuración |
29
+ | `contrato ot/` | Contratos de órdenes de trabajo |
30
+ | `notificaciones/` | Notificaciones (data adicional) |
31
+ | `scraping credential/` | Credenciales para scraping |
32
+ | `theme config country/` | Configuración de tema por país |
33
+
34
+ ## Naming
35
+
36
+ - Entidades: `[Nombre]ENTITY`
37
+ - DTOs: `[Nombre]DTO`
38
+ - Ejemplo: `UsuarioENTITY`, `EmpresaENTITY`, `DatosGeneralesDTO`, `SistemaDTO`, `PerfilENTITY`
39
+
40
+ ## Ubicación de archivos
41
+
42
+ ```
43
+ src/configuracion/
44
+ └── [nombre-modulo]/
45
+ └── shared/
46
+ ├── [nombre].entity.ts
47
+ └── dto/
48
+ └── [nombre]-dto.ts
49
+ ```
@@ -0,0 +1,71 @@
1
+ ---
2
+ name: ope-im
3
+ description: >
4
+ Dominio operativa/ — base de datos OPE_IM. Usar cuando se trabaje con
5
+ mantenimientos, procesos de integración externa (TOA, WAOO, WIN, Fibramas, Onnet,
6
+ Movistar, Somacyl, Tuves, TDC), órdenes de liquidación, order stock,
7
+ o cualquier entidad/DTO dentro de src/operativa/.
8
+ ---
9
+
10
+ # Skill: OPE_IM
11
+
12
+ Carpeta: `src/operativa/`
13
+ Base de datos MongoDB: **OPE_IM**
14
+
15
+ Contiene integraciones con sistemas externos de operadores de telecomunicaciones y procesos de mantenimiento.
16
+
17
+ ## Sub-dominios principales
18
+
19
+ ### `mantenimientos/`
20
+ Entidades de mantenimiento operativo.
21
+
22
+ ### `procesos/`
23
+ Integraciones con sistemas externos por operador:
24
+
25
+ | Carpeta | Operador / Sistema |
26
+ |---|---|
27
+ | `TOA orden liquidacion/` | TOA — órdenes de liquidación |
28
+ | `TOA orden liquidacion_db/` | TOA — órdenes de liquidación (versión BD) |
29
+ | `TOA Claro order stock/` | TOA Claro — order stock |
30
+ | `TOA order stock/` | TOA — order stock genérico |
31
+ | `toa_claro/` | TOA Claro (scraper + shared) |
32
+ | `toa_movistar/` | TOA Movistar |
33
+ | `toa_movistar_db/` | TOA Movistar (versión BD) |
34
+ | `baremos_toa/` | Baremos TOA (Chile + shared) |
35
+ | `liquidadas_toa/` | Órdenes TOA liquidadas |
36
+ | `valorizadas_toa/` | Órdenes TOA valorizadas |
37
+ | `onnet_fibra/` | Onnet Fibra (DTOs + utils) |
38
+ | `fibramas_order/` | Fibramas — órdenes |
39
+ | `fibramas_order_db/` | Fibramas — órdenes (versión BD) |
40
+ | `win_order/` | WIN — órdenes |
41
+ | `win_order_db/` | WIN — órdenes (versión BD) |
42
+ | `waoo_order_stock/` | WAOO — order stock |
43
+ | `cliente_waoo/` | WAOO — clientes |
44
+ | `somacyl_order/` | Somacyl — órdenes |
45
+ | `tuves/` | Tuves |
46
+ | `tuves_order_stock/` | Tuves — order stock |
47
+ | `tdc/` | TDC (Chile — DTOs + interfaces) |
48
+ | `stb_dth_toaperu/` | STB DTH TOA Perú |
49
+ | `order stock/` | Order stock genérico |
50
+ | `request number TTL/` | Request number TTL |
51
+
52
+ ## Naming
53
+
54
+ - Entidades: `[Nombre]ENTITY`
55
+ - DTOs: `[Nombre]DTO`
56
+ - Ejemplo: `ToaOrdenLiquidacionENTITY`, `BaremoToaENTITY`, `OnnetFibraENTITY`
57
+
58
+ ## Ubicación de archivos
59
+
60
+ ```
61
+ src/operativa/
62
+ ├── mantenimientos/
63
+ │ └── shared/
64
+ │ └── [nombre].entity.ts
65
+ └── procesos/
66
+ └── [nombre-operador]/
67
+ └── shared/
68
+ ├── [nombre].entity.ts
69
+ └── dto/
70
+ └── [nombre]-dto.ts
71
+ ```
@@ -0,0 +1,60 @@
1
+ ---
2
+ name: ope-logistica
3
+ description: >
4
+ Dominio logistica/ — base de datos OPE_LOGISTICA. Usar cuando se trabaje con
5
+ almacenes, bodega, stock, inventario, movimientos de almacén, consumo de material,
6
+ devoluciones, ítems, kits, o cualquier entidad/DTO dentro de src/logistica/.
7
+ ---
8
+
9
+ # Skill: OPE_LOGISTICA
10
+
11
+ Carpeta: `src/logistica/`
12
+ Base de datos MongoDB: **OPE_LOGISTICA**
13
+
14
+ También contiene parte de **MDL_CATALOGO** — catálogo de ítems, tipos de almacén, unidades de medida.
15
+
16
+ ## Sub-dominios principales
17
+
18
+ | Carpeta | Contenido |
19
+ |---|---|
20
+ | `almacen/` | Almacenes |
21
+ | `almacen extra/` | Almacenes extra |
22
+ | `bodega/` | Bodegas |
23
+ | `stock almacen/` | Stock en almacén |
24
+ | `stock almacen equipos/` | Stock de equipos en almacén |
25
+ | `stock personal/` | Stock asignado a personal |
26
+ | `stock personal equipos/` | Stock de equipos del personal |
27
+ | `movimiento almacen/` | Movimientos de almacén |
28
+ | `ingreso almacen/` | Ingresos a almacén |
29
+ | `salida almacen/` | Salidas de almacén |
30
+ | `devolucion almacen/` | Devoluciones de almacén |
31
+ | `consumo material/` | Consumo de material (incluye variante Alemania) |
32
+ | `consumos P117/` | Consumos protocolo P117 |
33
+ | `kitconsumo/` | Kits de consumo |
34
+ | `autoinventario/` | Autoinventario |
35
+ | `transaccion folios/` | Transacciones con folios |
36
+ | `atencion ordenes liquidadas/` | Atención de órdenes liquidadas |
37
+ | `items/` | Catálogo de ítems (incluye variante Alemania) — **MDL_CATALOGO** |
38
+ | `gran familia item/` | Gran familia de ítems — **MDL_CATALOGO** |
39
+ | `tipo almacen/` | Tipos de almacén — **MDL_CATALOGO** |
40
+ | `tipo movimiento almacen/` | Tipos de movimiento de almacén — **MDL_CATALOGO** |
41
+ | `tipo stock/` | Tipos de stock — **MDL_CATALOGO** |
42
+ | `unidad medida/` | Unidades de medida — **MDL_CATALOGO** |
43
+ | `procesos/navisionpreorden/` | Pre-órdenes Navision (DTOs, enums, requestDtos) |
44
+
45
+ ## Naming
46
+
47
+ - Entidades: `[Nombre]ENTITY`
48
+ - DTOs: `[Nombre]DTO`
49
+ - Ejemplo: `AlmacenENTITY`, `AlmacenDTO`, `StockAlmacenENTITY`, `MovimientoAlmacenENTITY`
50
+
51
+ ## Ubicación de archivos
52
+
53
+ ```
54
+ src/logistica/
55
+ └── [nombre-modulo]/
56
+ └── shared/
57
+ ├── [nombre].entity.ts
58
+ └── dto/
59
+ └── [nombre]-dto.ts
60
+ ```
@@ -0,0 +1,106 @@
1
+ ---
2
+ name: ope-pex
3
+ description: >
4
+ Dominio programados/ — base de datos OPE_PEX. Usar cuando se trabaje con
5
+ procesos programados de ejecución: obra, trabajo, cubicación, macroobra,
6
+ reservas (MO y material), reportes de producción, liberación de pagos,
7
+ mantenimientos de catálogos (agencia, cuadrilla, periodo, presupuesto),
8
+ o cualquier entidad/DTO dentro de src/programados/.
9
+ ---
10
+
11
+ # Skill: OPE_PEX
12
+
13
+ Carpeta: `src/programados/`
14
+ Base de datos MongoDB: **OPE_PEX**
15
+
16
+ Procesos programados de ejecución — el dominio más grande del paquete.
17
+
18
+ ## Sub-dominios principales
19
+
20
+ ### `Reportes/`
21
+
22
+ | Carpeta | Contenido |
23
+ |---|---|
24
+ | `LiberacionDePagos/` | Reporte de liberación de pagos (DTOs + requestDtos) |
25
+ | `ReporteProduccion/` | Reporte de producción (Alemania, Chile, Colombia — baremos y resumen) |
26
+ | `RptProduccionCurso_Baremos_Fases/` | Reporte producción en curso con baremos y fases |
27
+
28
+ ### `mantenimientos/`
29
+ Catálogos y configuraciones base de OPE_PEX:
30
+
31
+ | Carpeta | Contenido |
32
+ |---|---|
33
+ | `agencia/` | Agencias |
34
+ | `area_gom/` | Áreas GOM |
35
+ | `centro costos/` | Centros de costo |
36
+ | `contrato-pagos/` | Contratos de pago (Alemania) |
37
+ | `cuadrilla/` | Cuadrillas de trabajo |
38
+ | `mano obra global/` | Mano de obra global |
39
+ | `mano-obra-baremo/` | Mano de obra × baremo |
40
+ | `periodo/` | Períodos |
41
+ | `presupuesto-ot/` | Presupuesto de OT |
42
+ | `rm actividad/` | RM actividad |
43
+ | `rm comuna/` | RM comuna |
44
+ | `rm mano obra/` | RM mano de obra |
45
+ | `rm paquetizado/` | RM paquetizado |
46
+ | `rm-material/` | RM material |
47
+ | `rm-zonas-actividad/` | RM zonas de actividad |
48
+ | `tipo actividad mo/` | Tipos de actividad MO |
49
+ | `tipo obra/` | Tipos de obra |
50
+
51
+ ### `procesos/`
52
+ Procesos de ejecución programada:
53
+
54
+ | Carpeta | Contenido |
55
+ |---|---|
56
+ | `obra/` | Obra (Alemania AL02/AL04, Chile 9512, Colombia 9612, Perú 9112, shared) |
57
+ | `trabajo/` | Trabajo (Alemania + shared) |
58
+ | `macroobra/` | Macro-obra (Chile, Perú, shared) |
59
+ | `trabajoMacroObra/` | Trabajo en macro-obra (Alemania + shared) |
60
+ | `cubicacion/` | Cubicación (Alemania, Chile, Colombia, Perú, shared) |
61
+ | `reservaManoObra/` | Reserva de mano de obra (Alemania + shared) |
62
+ | `reservaManoObraRegularizacion/` | Regularización de reserva MO |
63
+ | `reservaMaterial/` | Reserva de material |
64
+ | `precioContratistaIssue/` | Precio contratista — issues (Alemania AL02 + shared) |
65
+ | `precioContratistaMO/` | Precio contratista MO (Alemania AL02/AL04 + shared) |
66
+ | `precioContratistaMaterial/` | Precio contratista material |
67
+ | `gom/` | GOM (Colombia + shared) |
68
+ | `Issue/` | Issues generales |
69
+ | `addressList_AL04/` | Lista de direcciones AL04 (Alemania) |
70
+ | `data-migrations/` | Migraciones de datos |
71
+ | `model mo sql/` | Modelo MO SQL (Perú) |
72
+ | `model obra sql/` | Modelo obra SQL (Perú) |
73
+
74
+ ## Naming
75
+
76
+ - Entidades: `[Nombre]ENTITY`
77
+ - DTOs: `[Nombre]DTO`
78
+ - Ejemplo: `ObraENTITY`, `TrabajoENTITY`, `CubicacionENTITY`, `ReservaManoObraENTITY`
79
+
80
+ ## Patrón por país
81
+
82
+ Muchos módulos tienen variantes por país dentro del mismo proceso:
83
+
84
+ ```
85
+ procesos/obra/
86
+ ├── alemania/AL02/ ← contrato alemán AL02
87
+ ├── alemania/AL04/ ← contrato alemán AL04
88
+ ├── chile/9512/ ← contrato chileno 9512
89
+ ├── colombia/9612/ ← contrato colombiano 9612
90
+ ├── peru/9112/ ← contrato peruano 9112
91
+ └── shared/ ← estructura base compartida
92
+ ```
93
+
94
+ ## Ubicación de archivos
95
+
96
+ ```
97
+ src/programados/
98
+ ├── Reportes/[nombre]/shared/(dto|request_dto)/
99
+ ├── mantenimientos/[nombre]/shared/(entity|dto)/
100
+ └── procesos/[nombre]/
101
+ ├── shared/
102
+ │ ├── [nombre].entity.ts
103
+ │ ├── dto/
104
+ │ └── requestDto/
105
+ └── [pais]/dto/
106
+ ```
@@ -0,0 +1,76 @@
1
+ ---
2
+ name: shared-dtos
3
+ description: >
4
+ Dominio shared/ — DTOs, enums, types y utils reutilizables en todos los dominios.
5
+ Usar cuando se necesite un DTO transversal como CodigoNombre, UsuarioDTO, o cualquier
6
+ estructura que se repite en múltiples colecciones/módulos. También contiene enums
7
+ globales, tipos TypeScript y utilidades de transformación.
8
+ ---
9
+
10
+ # Skill: Shared DTOs
11
+
12
+ Carpeta: `src/shared/`
13
+ **No tiene base de datos propia** — es código reutilizado por todos los dominios.
14
+
15
+ ## Sub-carpetas
16
+
17
+ ### `dto/`
18
+ DTOs transversales usados en múltiples entidades y dominios.
19
+
20
+ Ejemplos clave:
21
+
22
+ | DTO | Forma | Uso |
23
+ |---|---|---|
24
+ | `CodigoNombre` | `{ Codigo: string, Nombre: string }` | Referencia genérica a catálogos |
25
+ | `UsuarioDTO` | datos del usuario | Auditoría, asignaciones |
26
+ | `AlmacenDTO` | datos de almacén | Referencia a almacenes en otros módulos |
27
+ | `AutoinventarioDTO` | — | Inventario en múltiples dominios |
28
+ | `ZonasDTO` | — | Zonas de trabajo transversales |
29
+
30
+ > Si una estructura `{ Codigo, Nombre }` aparece en varios módulos, usar `CodigoNombre` de shared en vez de redefinirla.
31
+
32
+ ### `enums/`
33
+ Enums globales del sistema:
34
+
35
+ | Archivo | Contenido |
36
+ |---|---|
37
+ | `RequeridoEnum.ts` | Enum de campos requeridos |
38
+ | `StateInternalOrder.ts` | Estados de órdenes internas |
39
+ | `StateInternalOrderTOA.ts` | Estados de órdenes TOA |
40
+
41
+ ### `types/`
42
+ Tipos TypeScript globales:
43
+
44
+ | Archivo | Contenido |
45
+ |---|---|
46
+ | `sistema-recurso.ts` | Tipo de recurso del sistema |
47
+ | `state-inventory.ts` | Tipo de estado de inventario |
48
+
49
+ ### `utils/`
50
+ Utilidades de transformación usadas en decoradores `@Transform`:
51
+
52
+ | Utilidad | Función |
53
+ |---|---|
54
+ | `trimAndUpperCaseString` | `.trim().toUpperCase()` — la más usada |
55
+ | `smartDateTransformer` | Transforma strings a Date de forma segura |
56
+ | `convertStringsToDates` | Convierte strings ISO a Date en objetos |
57
+ | `convertTypeNumber` | Fuerza conversión a número |
58
+ | `forceString` | Fuerza conversión a string |
59
+ | `transformToDateIfEmpty` | Date con fallback si vacío |
60
+ | `enumToArray` | Convierte enum a array |
61
+ | `entity_generator` | Genera instancias de entidad con defaults |
62
+ | `entity_generator_under_hyphen` | Variante con naming hyphen |
63
+ | `validarYFormatearDatos` | Valida y formatea datos |
64
+ | `validateArrayBody` | Valida arrays en body |
65
+
66
+ ## Path aliases
67
+
68
+ ```ts
69
+ import { ... } from '@shared-dto/nombre-dto' // src/shared/dto/
70
+ import { ... } from '@shared-types/nombre-type' // src/shared/types/
71
+ import { ... } from '@shared-enums/nombre-enum' // src/shared/enums/
72
+ ```
73
+
74
+ ## Regla
75
+
76
+ Antes de crear un DTO nuevo, revisar si ya existe en `shared/dto/`. Si la misma forma de datos aparece en ≥2 módulos distintos, pertenece a `shared/`.
package/dist/index.d.mts CHANGED
@@ -802,7 +802,8 @@ declare enum ReasonNoFinalizedSomacyl {
802
802
  INSTALACION_INADECUADA = "Instalaci\u00F3n inadecuada",
803
803
  NEGATIVA_DE_CLIENTE = "Negativa de cliente",
804
804
  CLIENTE_AUSENTE = "Cliente ausente",
805
- OTRO = "Otro"
805
+ OTRO = "Otro",
806
+ INICIAL = ""
806
807
  }
807
808
 
808
809
  declare class MailStructureENTITY {
package/dist/index.d.ts CHANGED
@@ -802,7 +802,8 @@ declare enum ReasonNoFinalizedSomacyl {
802
802
  INSTALACION_INADECUADA = "Instalaci\u00F3n inadecuada",
803
803
  NEGATIVA_DE_CLIENTE = "Negativa de cliente",
804
804
  CLIENTE_AUSENTE = "Cliente ausente",
805
- OTRO = "Otro"
805
+ OTRO = "Otro",
806
+ INICIAL = ""
806
807
  }
807
808
 
808
809
  declare class MailStructureENTITY {
package/dist/index.js CHANGED
@@ -2606,13 +2606,13 @@ __decorateClass([
2606
2606
  __decorateClass([
2607
2607
  (0, import_class_validator46.IsString)({ message: "debe ser un texto" }),
2608
2608
  (0, import_class_validator46.IsNotEmpty)({ message: "es requerido" }),
2609
- (0, import_class_validator46.Length)(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
2609
+ (0, import_class_validator46.Length)(1, 200, { message: "debe tener entre 1 y 200 caracteres" }),
2610
2610
  (0, import_class_transformer48.Expose)()
2611
2611
  ], DetalleDTO.prototype, "CodigoBusqueda", 2);
2612
2612
  __decorateClass([
2613
2613
  (0, import_class_validator46.IsString)({ message: "debe ser un texto" }),
2614
2614
  (0, import_class_validator46.IsNotEmpty)({ message: "es requerido" }),
2615
- (0, import_class_validator46.Length)(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
2615
+ (0, import_class_validator46.Length)(1, 200, { message: "debe tener entre 1 y 200 caracteres" }),
2616
2616
  (0, import_class_transformer48.Expose)()
2617
2617
  ], DetalleDTO.prototype, "CodigoLlave", 2);
2618
2618
  __decorateClass([
@@ -4548,6 +4548,7 @@ var ReasonNoFinalizedSomacyl = /* @__PURE__ */ ((ReasonNoFinalizedSomacyl2) => {
4548
4548
  ReasonNoFinalizedSomacyl2["NEGATIVA_DE_CLIENTE"] = "Negativa de cliente";
4549
4549
  ReasonNoFinalizedSomacyl2["CLIENTE_AUSENTE"] = "Cliente ausente";
4550
4550
  ReasonNoFinalizedSomacyl2["OTRO"] = "Otro";
4551
+ ReasonNoFinalizedSomacyl2["INICIAL"] = "";
4551
4552
  return ReasonNoFinalizedSomacyl2;
4552
4553
  })(ReasonNoFinalizedSomacyl || {});
4553
4554
 
@@ -28709,13 +28710,13 @@ __decorateClass([
28709
28710
  __decorateClass([
28710
28711
  (0, import_class_validator481.IsString)({ message: "debe ser un texto" }),
28711
28712
  (0, import_class_validator481.IsNotEmpty)({ message: "es requerido" }),
28712
- (0, import_class_validator481.Length)(1, 70, { message: "debe tener entre 1 y 70 caracteres" }),
28713
+ (0, import_class_validator481.Length)(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
28713
28714
  (0, import_class_transformer483.Expose)()
28714
28715
  ], StockPersonalENTITY.prototype, "CodigoBusqueda", 2);
28715
28716
  __decorateClass([
28716
28717
  (0, import_class_validator481.IsString)({ message: "debe ser un texto" }),
28717
28718
  (0, import_class_validator481.IsNotEmpty)({ message: "es requerido" }),
28718
- (0, import_class_validator481.Length)(1, 50, { message: "debe tener entre 1 y 50 caracteres" }),
28719
+ (0, import_class_validator481.Length)(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
28719
28720
  (0, import_class_transformer483.Expose)()
28720
28721
  ], StockPersonalENTITY.prototype, "CodigoLlave", 2);
28721
28722
  __decorateClass([
@@ -47598,7 +47599,7 @@ var SomacylOrderENTITY = class {
47598
47599
  estado_actividad = "Pendiente" /* PENDIENTE */;
47599
47600
  estado_interno = "Pendiente" /* PENDIENTE */;
47600
47601
  observaciones_no_finalizada = "";
47601
- motivo_no_finalizado = "Instalaci\xF3n inadecuada" /* INSTALACION_INADECUADA */;
47602
+ motivo_no_finalizado = "" /* INICIAL */;
47602
47603
  observaciones_en_legados = "";
47603
47604
  planta = new PlantaSomacylDTO();
47604
47605
  numero_telefono = "";
package/dist/index.mjs CHANGED
@@ -1791,13 +1791,13 @@ __decorateClass([
1791
1791
  __decorateClass([
1792
1792
  IsString35({ message: "debe ser un texto" }),
1793
1793
  IsNotEmpty34({ message: "es requerido" }),
1794
- Length28(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
1794
+ Length28(1, 200, { message: "debe tener entre 1 y 200 caracteres" }),
1795
1795
  Expose43()
1796
1796
  ], DetalleDTO.prototype, "CodigoBusqueda", 2);
1797
1797
  __decorateClass([
1798
1798
  IsString35({ message: "debe ser un texto" }),
1799
1799
  IsNotEmpty34({ message: "es requerido" }),
1800
- Length28(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
1800
+ Length28(1, 200, { message: "debe tener entre 1 y 200 caracteres" }),
1801
1801
  Expose43()
1802
1802
  ], DetalleDTO.prototype, "CodigoLlave", 2);
1803
1803
  __decorateClass([
@@ -3733,6 +3733,7 @@ var ReasonNoFinalizedSomacyl = /* @__PURE__ */ ((ReasonNoFinalizedSomacyl2) => {
3733
3733
  ReasonNoFinalizedSomacyl2["NEGATIVA_DE_CLIENTE"] = "Negativa de cliente";
3734
3734
  ReasonNoFinalizedSomacyl2["CLIENTE_AUSENTE"] = "Cliente ausente";
3735
3735
  ReasonNoFinalizedSomacyl2["OTRO"] = "Otro";
3736
+ ReasonNoFinalizedSomacyl2["INICIAL"] = "";
3736
3737
  return ReasonNoFinalizedSomacyl2;
3737
3738
  })(ReasonNoFinalizedSomacyl || {});
3738
3739
 
@@ -28047,13 +28048,13 @@ __decorateClass([
28047
28048
  __decorateClass([
28048
28049
  IsString370({ message: "debe ser un texto" }),
28049
28050
  IsNotEmpty304({ message: "es requerido" }),
28050
- Length238(1, 70, { message: "debe tener entre 1 y 70 caracteres" }),
28051
+ Length238(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
28051
28052
  Expose478()
28052
28053
  ], StockPersonalENTITY.prototype, "CodigoBusqueda", 2);
28053
28054
  __decorateClass([
28054
28055
  IsString370({ message: "debe ser un texto" }),
28055
28056
  IsNotEmpty304({ message: "es requerido" }),
28056
- Length238(1, 50, { message: "debe tener entre 1 y 50 caracteres" }),
28057
+ Length238(1, 100, { message: "debe tener entre 1 y 100 caracteres" }),
28057
28058
  Expose478()
28058
28059
  ], StockPersonalENTITY.prototype, "CodigoLlave", 2);
28059
28060
  __decorateClass([
@@ -47108,7 +47109,7 @@ var SomacylOrderENTITY = class {
47108
47109
  estado_actividad = "Pendiente" /* PENDIENTE */;
47109
47110
  estado_interno = "Pendiente" /* PENDIENTE */;
47110
47111
  observaciones_no_finalizada = "";
47111
- motivo_no_finalizado = "Instalaci\xF3n inadecuada" /* INSTALACION_INADECUADA */;
47112
+ motivo_no_finalizado = "" /* INICIAL */;
47112
47113
  observaciones_en_legados = "";
47113
47114
  planta = new PlantaSomacylDTO();
47114
47115
  numero_telefono = "";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sigo-entities",
3
- "version": "1.2.353",
3
+ "version": "1.2.355",
4
4
  "description": "Desarrollo de modelos de datos SIGO",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",