dmencu 0.3.34 → 0.3.36

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.
Files changed (127) hide show
  1. package/dist/client/client/client.d.ts +1 -1
  2. package/dist/client/client/client.js +540 -539
  3. package/dist/client/client/menu.js +2 -2
  4. package/dist/client/unlogged/abrir-formulario.d.ts +12 -12
  5. package/dist/client/unlogged/abrir-formulario.js +102 -102
  6. package/dist/client/unlogged/bypass-formulario.d.ts +200 -200
  7. package/dist/client/unlogged/bypass-formulario.js +1041 -1041
  8. package/dist/client/unlogged/redux-formulario.d.ts +349 -349
  9. package/dist/client/unlogged/redux-formulario.js +317 -317
  10. package/dist/client/unlogged/tipos.d.ts +469 -469
  11. package/dist/client/unlogged/tipos.js +21 -21
  12. package/dist/server/server/app-dmencu.d.ts +1511 -1511
  13. package/dist/server/server/app-dmencu.js +649 -649
  14. package/dist/server/server/def-config.d.ts +1 -1
  15. package/dist/server/server/def-config.js +14 -14
  16. package/dist/server/server/procedures-dmencu.d.ts +6 -6
  17. package/dist/server/server/procedures-dmencu.js +854 -854
  18. package/dist/server/server/server-dmencu.d.ts +1 -1
  19. package/dist/server/server/server-dmencu.js +20 -20
  20. package/dist/server/server/table-acciones.d.ts +3 -3
  21. package/dist/server/server/table-acciones.js +53 -53
  22. package/dist/server/server/table-areas.d.ts +3 -3
  23. package/dist/server/server/table-areas.js +88 -88
  24. package/dist/server/server/table-comunas.d.ts +3 -3
  25. package/dist/server/server/table-comunas.js +28 -28
  26. package/dist/server/server/table-control_campo.d.ts +11 -11
  27. package/dist/server/server/table-control_campo.js +71 -71
  28. package/dist/server/server/table-control_resumen.d.ts +3 -3
  29. package/dist/server/server/table-control_resumen.js +18 -18
  30. package/dist/server/server/table-encuestadores.d.ts +3 -3
  31. package/dist/server/server/table-encuestadores.js +18 -18
  32. package/dist/server/server/table-estados.d.ts +3 -3
  33. package/dist/server/server/table-estados.js +60 -60
  34. package/dist/server/server/table-estados_acciones.d.ts +3 -3
  35. package/dist/server/server/table-estados_acciones.js +38 -38
  36. package/dist/server/server/table-hogares.d.ts +3 -3
  37. package/dist/server/server/table-hogares.js +156 -156
  38. package/dist/server/server/table-hogares_sup.d.ts +3 -3
  39. package/dist/server/server/table-hogares_sup.js +191 -191
  40. package/dist/server/server/table-lotes.d.ts +3 -3
  41. package/dist/server/server/table-lotes.js +35 -35
  42. package/dist/server/server/table-mis_encuestadores.d.ts +3 -3
  43. package/dist/server/server/table-mis_encuestadores.js +56 -56
  44. package/dist/server/server/table-mis_tareas.d.ts +3 -3
  45. package/dist/server/server/table-mis_tareas.js +18 -18
  46. package/dist/server/server/table-mis_tareas_areas.d.ts +3 -3
  47. package/dist/server/server/table-mis_tareas_areas.js +20 -20
  48. package/dist/server/server/table-no_rea.d.ts +3 -3
  49. package/dist/server/server/table-no_rea.js +32 -32
  50. package/dist/server/server/table-no_rea_sup.d.ts +3 -3
  51. package/dist/server/server/table-no_rea_sup.js +32 -32
  52. package/dist/server/server/table-operaciones.d.ts +3 -3
  53. package/dist/server/server/table-operaciones.js +30 -30
  54. package/dist/server/server/table-parametros.d.ts +3 -3
  55. package/dist/server/server/table-parametros.js +39 -39
  56. package/dist/server/server/table-permisos.d.ts +3 -3
  57. package/dist/server/server/table-permisos.js +31 -31
  58. package/dist/server/server/table-personal.d.ts +6 -6
  59. package/dist/server/server/table-personal.js +56 -56
  60. package/dist/server/server/table-personal_rol.d.ts +3 -3
  61. package/dist/server/server/table-personal_rol.js +36 -36
  62. package/dist/server/server/table-personas.d.ts +3 -3
  63. package/dist/server/server/table-personas.js +448 -448
  64. package/dist/server/server/table-personas_sup.d.ts +3 -3
  65. package/dist/server/server/table-personas_sup.js +93 -93
  66. package/dist/server/server/table-recepcionistas.d.ts +3 -3
  67. package/dist/server/server/table-recepcionistas.js +18 -18
  68. package/dist/server/server/table-recuperadores.d.ts +3 -3
  69. package/dist/server/server/table-recuperadores.js +18 -18
  70. package/dist/server/server/table-resultados_tarea.d.ts +3 -3
  71. package/dist/server/server/table-resultados_tarea.js +28 -28
  72. package/dist/server/server/table-roles.d.ts +3 -3
  73. package/dist/server/server/table-roles.js +32 -32
  74. package/dist/server/server/table-roles_permisos.d.ts +3 -3
  75. package/dist/server/server/table-roles_permisos.js +35 -35
  76. package/dist/server/server/table-roles_subordinados.d.ts +3 -3
  77. package/dist/server/server/table-roles_subordinados.js +32 -32
  78. package/dist/server/server/table-semanas.d.ts +3 -3
  79. package/dist/server/server/table-semanas.js +34 -34
  80. package/dist/server/server/table-sincronizaciones.d.ts +3 -3
  81. package/dist/server/server/table-sincronizaciones.js +30 -30
  82. package/dist/server/server/table-supervisores.d.ts +3 -3
  83. package/dist/server/server/table-supervisores.js +18 -18
  84. package/dist/server/server/table-tareas.d.ts +3 -3
  85. package/dist/server/server/table-tareas.js +46 -46
  86. package/dist/server/server/table-tareas_areas.d.ts +3 -3
  87. package/dist/server/server/table-tareas_areas.js +55 -55
  88. package/dist/server/server/table-tareas_tem.d.ts +3 -3
  89. package/dist/server/server/table-tareas_tem.js +104 -105
  90. package/dist/server/server/table-tareas_tem_asignables.d.ts +1 -1
  91. package/dist/server/server/table-tareas_tem_asignables.js +5 -5
  92. package/dist/server/server/table-tareas_tem_recepcion.d.ts +3 -5
  93. package/dist/server/server/table-tareas_tem_recepcion.js +33 -43
  94. package/dist/server/server/table-tem.d.ts +3 -3
  95. package/dist/server/server/table-tem.js +192 -192
  96. package/dist/server/server/table-tem_asignacion.d.ts +3 -0
  97. package/dist/server/server/table-tem_asignacion.js +51 -0
  98. package/dist/server/server/table-tem_recepcion.d.ts +3 -3
  99. package/dist/server/server/table-tem_recepcion.js +18 -18
  100. package/dist/server/server/table-usuarios.d.ts +3 -3
  101. package/dist/server/server/table-usuarios.js +58 -58
  102. package/dist/server/server/table-visitas.d.ts +3 -3
  103. package/dist/server/server/table-visitas.js +91 -91
  104. package/dist/server/server/table-visitas_sup.d.ts +3 -3
  105. package/dist/server/server/table-visitas_sup.js +91 -91
  106. package/dist/server/server/table-viviendas.d.ts +3 -3
  107. package/dist/server/server/table-viviendas.js +299 -299
  108. package/dist/server/server/types-dmencu.d.ts +24 -24
  109. package/dist/server/server/types-dmencu.js +32 -32
  110. package/dist/server/unlogged/tipos.d.ts +469 -469
  111. package/dist/server/unlogged/tipos.js +21 -21
  112. package/dist/unlogged/unlogged/abrir-formulario.d.ts +12 -12
  113. package/dist/unlogged/unlogged/abrir-formulario.js +102 -102
  114. package/dist/unlogged/unlogged/adapt.js +7 -7
  115. package/dist/unlogged/unlogged/bypass-formulario.d.ts +200 -200
  116. package/dist/unlogged/unlogged/bypass-formulario.js +1041 -1041
  117. package/dist/unlogged/unlogged/redux-formulario.d.ts +349 -349
  118. package/dist/unlogged/unlogged/redux-formulario.js +317 -317
  119. package/dist/unlogged/unlogged/render-formulario.d.ts +54 -54
  120. package/dist/unlogged/unlogged/render-formulario.js +1485 -1485
  121. package/dist/unlogged/unlogged/render-general.d.ts +126 -126
  122. package/dist/unlogged/unlogged/render-general.js +184 -184
  123. package/dist/unlogged/unlogged/tipos.d.ts +469 -469
  124. package/dist/unlogged/unlogged/tipos.js +21 -21
  125. package/dist/unlogged/unlogged/unlogged.d.ts +1 -1
  126. package/dist/unlogged/unlogged/unlogged.js +162 -162
  127. package/package.json +1 -1
@@ -1,95 +1,95 @@
1
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
2
- if (k2 === undefined) k2 = k;
3
- var desc = Object.getOwnPropertyDescriptor(m, k);
4
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
5
- desc = { enumerable: true, get: function() { return m[k]; } };
6
- }
7
- Object.defineProperty(o, k2, desc);
8
- }) : (function(o, m, k, k2) {
9
- if (k2 === undefined) k2 = k;
10
- o[k2] = m[k];
11
- }));
12
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
13
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
14
- };
15
- (function (factory) {
16
- if (typeof module === "object" && typeof module.exports === "object") {
17
- var v = factory(require, exports);
18
- if (v !== undefined) module.exports = v;
19
- }
20
- else if (typeof define === "function" && define.amd) {
21
- define(["require", "exports", "like-ar", "./types-dmencu", "pg-promise-strict", "best-globals", "fs", "expre-parser"], factory);
22
- }
23
- })(function (require, exports) {
24
- "use strict";
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.ProceduresDmEncu = exports.setHdrQuery = exports.getOperativoActual = void 0;
27
- const likeAr = require("like-ar");
28
- __exportStar(require("./types-dmencu"), exports);
29
- const pg_promise_strict_1 = require("pg-promise-strict");
30
- const best_globals_1 = require("best-globals");
31
- const fs_1 = require("fs");
32
- const ExpresionParser = require("expre-parser");
33
- var path = require('path');
34
- var sqlTools = require('sql-tools');
35
- var discrepances = require('discrepances');
36
- const formPrincipal = 'F:F1';
37
- const MAIN_TABLENAME = 'viviendas';
38
- const getOperativoActual = async (context) => {
39
- var _a;
40
- var be = context.be;
41
- var result = await be.procedure.table_data.coreFunction(context, { table: `parametros`, fixedFields: [] });
42
- if ((_a = result[0]) === null || _a === void 0 ? void 0 : _a.operativo) {
43
- return result[0].operativo;
44
- }
45
- else {
46
- throw Error('no se configuró un operativo en la tabla parámetros');
47
- }
48
- };
49
- exports.getOperativoActual = getOperativoActual;
50
- function createStructure(context, tableName) {
51
- var be = context.be;
52
- var mainTableDef = be.tableStructures[tableName](context);
53
- var getPkFromTableDef = function getPkFromTableDef(tableDef) {
54
- return tableDef.primaryKey.map(function (pk) {
55
- return { fieldName: pk };
56
- });
57
- };
58
- var getFkFromTableDef = function getFkFromTableDef(tableDef, parentTableName) {
59
- // return tableDef.foreignKeys? tableDef.foreignKeys.map(fk=>fk.fields): [];
60
- let parentFk = tableDef.foreignKeys.find(fk => fk.references == parentTableName);
61
- return parentFk ? parentFk.fields : [];
62
- };
63
- var struct = {
64
- tableName: mainTableDef.name,
65
- pkFields: getPkFromTableDef(mainTableDef),
66
- childTables: []
67
- };
68
- if (mainTableDef.detailTables && mainTableDef.detailTables.length) {
69
- mainTableDef.detailTables.forEach(function (detailTable) {
70
- struct.childTables.push((0, best_globals_1.changing)(createStructure(context, detailTable.table), { fkFields: getFkFromTableDef(be.tableStructures[detailTable.table](context), tableName) }));
71
- });
72
- }
73
- return struct;
74
- }
75
- var getParametersAndSettersForUpdateTem = async (context, operativo, idEnc, respuestasUAPrincipal, tarea) => {
1
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
2
+ if (k2 === undefined) k2 = k;
3
+ var desc = Object.getOwnPropertyDescriptor(m, k);
4
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
5
+ desc = { enumerable: true, get: function() { return m[k]; } };
6
+ }
7
+ Object.defineProperty(o, k2, desc);
8
+ }) : (function(o, m, k, k2) {
9
+ if (k2 === undefined) k2 = k;
10
+ o[k2] = m[k];
11
+ }));
12
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
13
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
14
+ };
15
+ (function (factory) {
16
+ if (typeof module === "object" && typeof module.exports === "object") {
17
+ var v = factory(require, exports);
18
+ if (v !== undefined) module.exports = v;
19
+ }
20
+ else if (typeof define === "function" && define.amd) {
21
+ define(["require", "exports", "like-ar", "./types-dmencu", "pg-promise-strict", "best-globals", "fs", "expre-parser"], factory);
22
+ }
23
+ })(function (require, exports) {
24
+ "use strict";
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.ProceduresDmEncu = exports.setHdrQuery = exports.getOperativoActual = void 0;
27
+ const likeAr = require("like-ar");
28
+ __exportStar(require("./types-dmencu"), exports);
29
+ const pg_promise_strict_1 = require("pg-promise-strict");
30
+ const best_globals_1 = require("best-globals");
31
+ const fs_1 = require("fs");
32
+ const ExpresionParser = require("expre-parser");
33
+ var path = require('path');
34
+ var sqlTools = require('sql-tools');
35
+ var discrepances = require('discrepances');
36
+ const formPrincipal = 'F:F1';
37
+ const MAIN_TABLENAME = 'viviendas';
38
+ const getOperativoActual = async (context) => {
39
+ var _a;
40
+ var be = context.be;
41
+ var result = await be.procedure.table_data.coreFunction(context, { table: `parametros`, fixedFields: [] });
42
+ if ((_a = result[0]) === null || _a === void 0 ? void 0 : _a.operativo) {
43
+ return result[0].operativo;
44
+ }
45
+ else {
46
+ throw Error('no se configuró un operativo en la tabla parámetros');
47
+ }
48
+ };
49
+ exports.getOperativoActual = getOperativoActual;
50
+ function createStructure(context, tableName) {
51
+ var be = context.be;
52
+ var mainTableDef = be.tableStructures[tableName](context);
53
+ var getPkFromTableDef = function getPkFromTableDef(tableDef) {
54
+ return tableDef.primaryKey.map(function (pk) {
55
+ return { fieldName: pk };
56
+ });
57
+ };
58
+ var getFkFromTableDef = function getFkFromTableDef(tableDef, parentTableName) {
59
+ // return tableDef.foreignKeys? tableDef.foreignKeys.map(fk=>fk.fields): [];
60
+ let parentFk = tableDef.foreignKeys.find(fk => fk.references == parentTableName);
61
+ return parentFk ? parentFk.fields : [];
62
+ };
63
+ var struct = {
64
+ tableName: mainTableDef.name,
65
+ pkFields: getPkFromTableDef(mainTableDef),
66
+ childTables: []
67
+ };
68
+ if (mainTableDef.detailTables && mainTableDef.detailTables.length) {
69
+ mainTableDef.detailTables.forEach(function (detailTable) {
70
+ struct.childTables.push((0, best_globals_1.changing)(createStructure(context, detailTable.table), { fkFields: getFkFromTableDef(be.tableStructures[detailTable.table](context), tableName) }));
71
+ });
72
+ }
73
+ return struct;
74
+ }
75
+ var getParametersAndSettersForUpdateTem = async (context, operativo, idEnc, respuestasUAPrincipal, tarea) => {
76
76
  var registraEstadoEnTem = (await context.client.query(`select registra_estado_en_tem
77
77
  from tareas
78
- where operativo=$1 and tarea = $2`, [operativo, tarea]).fetchUniqueValue()).value;
79
- var params = [operativo, idEnc, respuestasUAPrincipal];
80
- var setters = `json_encuesta = $3`;
81
- //TODO ARREGLAR ESTE HORROR, GENERALIZAR
82
- if (tarea == 'supe') {
83
- setters += `, resumen_estado_sup=$4, norea_sup=$5, rea_sup=$6`;
84
- params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);
85
- }
86
- else {
87
- setters += `, resumen_estado=$4, norea=$5, rea=$6`;
88
- params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);
89
- }
90
- return { setters, params };
91
- };
92
- var getHdrQuery = function getHdrQuery(quotedCondViv) {
78
+ where operativo=$1 and tarea = $2`, [operativo, tarea]).fetchUniqueValue()).value;
79
+ var params = [operativo, idEnc, respuestasUAPrincipal];
80
+ var setters = `json_encuesta = $3`;
81
+ //TODO ARREGLAR ESTE HORROR, GENERALIZAR
82
+ if (tarea == 'supe') {
83
+ setters += `, resumen_estado_sup=$4, norea_sup=$5, rea_sup=$6`;
84
+ params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);
85
+ }
86
+ else {
87
+ setters += `, resumen_estado=$4, norea=$5, rea=$6`;
88
+ params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);
89
+ }
90
+ return { setters, params };
91
+ };
92
+ var getHdrQuery = function getHdrQuery(quotedCondViv) {
93
93
  return `
94
94
  with viviendas as
95
95
  (select t.enc, t.json_encuesta as respuestas, t.resumen_estado as "resumenEstado",
@@ -131,68 +131,68 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
131
131
  group by area, observaciones_hdr`, 'fecha')} as cargas,
132
132
  ${(0, pg_promise_strict_1.jsono)(`select enc, jsonb_build_object('tem', tem, 'tarea', tarea) as otras from viviendas`, 'enc', `otras ||'{}'::jsonb`)}
133
133
  as "informacionHdr"
134
- `;
135
- };
136
- var setHdrQuery = (myFun) => getHdrQuery = myFun;
137
- exports.setHdrQuery = setHdrQuery;
134
+ `;
135
+ };
136
+ var setHdrQuery = (myFun) => getHdrQuery = myFun;
137
+ exports.setHdrQuery = setHdrQuery;
138
138
  const getUAPrincipal = async (client, operativo) => (await client.query(`select unidad_analisis
139
139
  from unidad_analisis
140
140
  where operativo= $1 and principal
141
- `, [operativo]).fetchUniqueValue()).value;
142
- var funcionesConocidas = {};
143
- var compiler = new ExpresionParser.Compiler({
144
- language: 'js',
145
- varWrapper: (var_name) => `helpers.null2zero(valores.${var_name})`,
146
- funWrapper: (functionName) => {
147
- if (!funcionesConocidas[functionName]) {
148
- console.log(functionName);
149
- funcionesConocidas[functionName] = true;
150
- }
151
- return `helpers.funs.${functionName}`;
152
- }
153
- });
154
- function compilarExpresion(expresion) {
155
- return compiler.toCode(ExpresionParser.parse(expresion
156
- .replace(/\bis distinct from\b/gi, ' <> ')
157
- .replace(/!!/gi, ' '))).replace(/helpers\.funs\.blanco\(helpers.null2zero\(/g, 'helpers.funs.blanco((')
158
- .replace(/helpers\.funs\.informado\(helpers.null2zero\(/g, 'helpers.funs.informado((');
159
- }
160
- function compilarExpresiones(casillero) {
161
- var _a, _b;
162
- if (!casillero) {
163
- return;
164
- }
165
- if (casillero.data.expresion_habilitar) {
166
- casillero.data.expresion_habilitar_js = compilarExpresion(casillero.data.expresion_habilitar);
167
- }
168
- if ((_a = casillero.data.especial) === null || _a === void 0 ? void 0 : _a.autoing) {
169
- var partes = (_b = casillero.data.especial) === null || _b === void 0 ? void 0 : _b.autoing.split('=>');
170
- if (partes.length > 1) {
171
- var precondicion = partes[0];
172
- var valor = partes.slice(1).join('=>');
173
- casillero.data.expresion_autoingresar_js = `(${compilarExpresion(precondicion)})?(${compilarExpresion(valor)}):null`;
174
- }
175
- else {
176
- casillero.data.expresion_autoingresar_js = compilarExpresion(partes[0]);
177
- }
178
- }
179
- for (var casilleroInterno of casillero.childs)
180
- compilarExpresiones(casilleroInterno);
181
- }
182
- exports.ProceduresDmEncu = [
183
- {
184
- action: 'operativo_estructura_completa',
185
- parameters: [
186
- { name: 'operativo', typeName: 'text', references: 'operativos' },
187
- ],
188
- resultOk: 'desplegarFormulario',
189
- coreFunction: async function (context, parameters) {
190
- var be = context.be;
141
+ `, [operativo]).fetchUniqueValue()).value;
142
+ var funcionesConocidas = {};
143
+ var compiler = new ExpresionParser.Compiler({
144
+ language: 'js',
145
+ varWrapper: (var_name) => `helpers.null2zero(valores.${var_name})`,
146
+ funWrapper: (functionName) => {
147
+ if (!funcionesConocidas[functionName]) {
148
+ console.log(functionName);
149
+ funcionesConocidas[functionName] = true;
150
+ }
151
+ return `helpers.funs.${functionName}`;
152
+ }
153
+ });
154
+ function compilarExpresion(expresion) {
155
+ return compiler.toCode(ExpresionParser.parse(expresion
156
+ .replace(/\bis distinct from\b/gi, ' <> ')
157
+ .replace(/!!/gi, ' '))).replace(/helpers\.funs\.blanco\(helpers.null2zero\(/g, 'helpers.funs.blanco((')
158
+ .replace(/helpers\.funs\.informado\(helpers.null2zero\(/g, 'helpers.funs.informado((');
159
+ }
160
+ function compilarExpresiones(casillero) {
161
+ var _a, _b;
162
+ if (!casillero) {
163
+ return;
164
+ }
165
+ if (casillero.data.expresion_habilitar) {
166
+ casillero.data.expresion_habilitar_js = compilarExpresion(casillero.data.expresion_habilitar);
167
+ }
168
+ if ((_a = casillero.data.especial) === null || _a === void 0 ? void 0 : _a.autoing) {
169
+ var partes = (_b = casillero.data.especial) === null || _b === void 0 ? void 0 : _b.autoing.split('=>');
170
+ if (partes.length > 1) {
171
+ var precondicion = partes[0];
172
+ var valor = partes.slice(1).join('=>');
173
+ casillero.data.expresion_autoingresar_js = `(${compilarExpresion(precondicion)})?(${compilarExpresion(valor)}):null`;
174
+ }
175
+ else {
176
+ casillero.data.expresion_autoingresar_js = compilarExpresion(partes[0]);
177
+ }
178
+ }
179
+ for (var casilleroInterno of casillero.childs)
180
+ compilarExpresiones(casilleroInterno);
181
+ }
182
+ exports.ProceduresDmEncu = [
183
+ {
184
+ action: 'operativo_estructura_completa',
185
+ parameters: [
186
+ { name: 'operativo', typeName: 'text', references: 'operativos' },
187
+ ],
188
+ resultOk: 'desplegarFormulario',
189
+ coreFunction: async function (context, parameters) {
190
+ var be = context.be;
191
191
  var result = await context.client.query(`select casilleros_jerarquizados($1) as formularios,
192
192
  ${(0, pg_promise_strict_1.jsono)(`select unidad_analisis, padre, pk_agregada, '{}'::jsonb as hijas from unidad_analisis`, 'unidad_analisis')} as unidades_analisis
193
- `, [parameters.operativo]).fetchUniqueRow();
194
- likeAr(result.row.formularios).forEach(f => compilarExpresiones(f));
195
- // Hermanos son los formularios que están implantados en otro formulario de la misma UA. Por ejemplo el A1 en el S1
193
+ `, [parameters.operativo]).fetchUniqueRow();
194
+ likeAr(result.row.formularios).forEach(f => compilarExpresiones(f));
195
+ // Hermanos son los formularios que están implantados en otro formulario de la misma UA. Por ejemplo el A1 en el S1
196
196
  var resultHermanos = await context.client.query(`
197
197
  select o.id_casillero as id_formulario, o.unidad_analisis, 'BF_'||o.casillero boton, bf.casillero, bf.padre, fp.casillero, fp.unidad_analisis
198
198
  from casilleros o left join casilleros bf
@@ -204,802 +204,802 @@ select o.id_casillero as id_formulario, o.unidad_analisis, 'BF_'||o.casillero bo
204
204
  and fp.operativo = bf.operativo
205
205
  where o.tipoc = 'F'
206
206
  and o.unidad_analisis = fp.unidad_analisis
207
- and o.operativo = $1`, [parameters.operativo]).fetchAll();
208
- resultHermanos.rows.forEach(row => {
209
- result.row.formularios[row.id_formulario].data.hermano = true;
210
- });
211
- function completarUA(ua, idUa, uAs) {
212
- if (ua.padre) {
213
- uAs[ua.padre].hijas[idUa] = ua;
214
- }
215
- else {
216
- ua.principal = true;
217
- }
218
- }
219
- likeAr(result.row.unidades_analisis).forEach((ua, idUa) => completarUA(ua, idUa, result.row.unidades_analisis));
207
+ and o.operativo = $1`, [parameters.operativo]).fetchAll();
208
+ resultHermanos.rows.forEach(row => {
209
+ result.row.formularios[row.id_formulario].data.hermano = true;
210
+ });
211
+ function completarUA(ua, idUa, uAs) {
212
+ if (ua.padre) {
213
+ uAs[ua.padre].hijas[idUa] = ua;
214
+ }
215
+ else {
216
+ ua.principal = true;
217
+ }
218
+ }
219
+ likeAr(result.row.unidades_analisis).forEach((ua, idUa) => completarUA(ua, idUa, result.row.unidades_analisis));
220
220
  var configSorteo = (await context.client.query(`
221
221
  select config_sorteo
222
222
  from operativos
223
223
  where operativo = $1
224
- `, [parameters.operativo]).fetchUniqueValue()).value;
225
- let compilarExpresionesDominios = (expresionesDominio) => likeAr(expresionesDominio)
226
- .map((expr, dominio) => ({ dominio, expr: compilarExpresion(expr.expr) }))
227
- .plain();
228
- if (configSorteo) {
229
- likeAr(configSorteo).forEach((configSorteoFormulario) => {
230
- configSorteoFormulario.expr_incompletitud_js = compilarExpresionesDominios(configSorteoFormulario.expr_incompletitud);
231
- configSorteoFormulario.filtro_js = compilarExpresionesDominios(configSorteoFormulario.filtro);
232
- });
233
- }
234
- return { timestamp: be.timestampEstructura, ...result.row, operativo: parameters.operativo, configSorteo, noReas: be.caches.tableContent.no_rea, noReasSup: be.caches.tableContent.no_rea_sup };
235
- }
236
- },
237
- {
238
- action: 'generar_formularios',
239
- parameters: [
240
- { name: 'annio', typeName: 'integer', references: 'annio' },
241
- { name: 'mes', typeName: 'integer', references: 'mes' },
242
- { name: 'lote', typeName: 'integer', references: 'lotes' },
243
- ],
244
- coreFunction: async function (context, parameters) {
245
- var be = context.be;
246
- const OPERATIVO = await (0, exports.getOperativoActual)(context);
224
+ `, [parameters.operativo]).fetchUniqueValue()).value;
225
+ let compilarExpresionesDominios = (expresionesDominio) => likeAr(expresionesDominio)
226
+ .map((expr, dominio) => ({ dominio, expr: compilarExpresion(expr.expr) }))
227
+ .plain();
228
+ if (configSorteo) {
229
+ likeAr(configSorteo).forEach((configSorteoFormulario) => {
230
+ configSorteoFormulario.expr_incompletitud_js = compilarExpresionesDominios(configSorteoFormulario.expr_incompletitud);
231
+ configSorteoFormulario.filtro_js = compilarExpresionesDominios(configSorteoFormulario.filtro);
232
+ });
233
+ }
234
+ return { timestamp: be.timestampEstructura, ...result.row, operativo: parameters.operativo, configSorteo, noReas: be.caches.tableContent.no_rea, noReasSup: be.caches.tableContent.no_rea_sup };
235
+ }
236
+ },
237
+ {
238
+ action: 'generar_formularios',
239
+ parameters: [
240
+ { name: 'annio', typeName: 'integer', references: 'annio' },
241
+ { name: 'mes', typeName: 'integer', references: 'mes' },
242
+ { name: 'lote', typeName: 'integer', references: 'lotes' },
243
+ ],
244
+ coreFunction: async function (context, parameters) {
245
+ var be = context.be;
246
+ const OPERATIVO = await (0, exports.getOperativoActual)(context);
247
247
  let resultUA = await context.client.query(`select *
248
248
  from unidad_analisis
249
249
  where principal = true and operativo = $1
250
- `, [OPERATIVO]).fetchOneRowIfExists();
251
- if (resultUA.rowCount === 0) {
252
- throw new Error('No se configuró una unidad de analisis como principal');
253
- }
254
- let row = resultUA.row;
255
- let resultPreguntas = await be.procedure.preguntas_ua_traer.coreFunction(context, row);
256
- var contenedorVacio = {};
257
- resultPreguntas.forEach(function (defPregunta) {
258
- contenedorVacio[defPregunta.var_name] = defPregunta.unidad_analisis ? [] : null;
259
- });
260
- contenedorVacio.annio = parameters.annio;
261
- contenedorVacio.mes = parameters.mes;
262
- contenedorVacio.lote = parameters.lote;
250
+ `, [OPERATIVO]).fetchOneRowIfExists();
251
+ if (resultUA.rowCount === 0) {
252
+ throw new Error('No se configuró una unidad de analisis como principal');
253
+ }
254
+ let row = resultUA.row;
255
+ let resultPreguntas = await be.procedure.preguntas_ua_traer.coreFunction(context, row);
256
+ var contenedorVacio = {};
257
+ resultPreguntas.forEach(function (defPregunta) {
258
+ contenedorVacio[defPregunta.var_name] = defPregunta.unidad_analisis ? [] : null;
259
+ });
260
+ contenedorVacio.annio = parameters.annio;
261
+ contenedorVacio.mes = parameters.mes;
262
+ contenedorVacio.lote = parameters.lote;
263
263
  var result = await context.client.query(`select debe_haber.id_caso, s as id
264
264
  from (select lote, armar_id(annio, mes, lote, s) as id_caso, s
265
265
  from (select annio,mes,lote, cant_cues from lotes where (annio,mes,lote)=($2,$3,$4)) r, lateral generate_series(1,cant_cues) s
266
266
  ) debe_haber left join defgen hay on hay.id_caso = debe_haber.id_caso and hay.operativo=$1
267
- where hay.id_caso is null`, [OPERATIVO, parameters.annio, parameters.mes, parameters.lote]).fetchAll();
268
- var params = { operativo: OPERATIVO };
269
- for (var i = 0; i < result.rowCount; i++) {
270
- await be.procedure.caso_guardar.coreFunction(context, (0, best_globals_1.changing)(params, { id_caso: result.rows[i].id_caso, datos_caso: (0, best_globals_1.changing)(contenedorVacio, { id: result.rows[i].id }) }));
271
- }
272
- return { agregadas: result.rowCount };
273
- }
274
- },
275
- {
276
- action: 'upload_file',
277
- progress: true,
278
- parameters: [
279
- { name: 'id_adjunto', typeName: 'integer' },
280
- { name: 'nombre', typeName: 'text' },
281
- ],
282
- files: { count: 1 },
283
- coreFunction: function (context, parameters, files) {
284
- let be = context.be;
285
- let client = context.client;
286
- context.informProgress({ message: be.messages.fileUploaded });
287
- let file = files[0];
288
- let ext = path.extname(file.path).substr(1);
289
- let originalFilename = file.originalFilename.slice(0, -(ext.length + 1));
290
- let filename = parameters.nombre || originalFilename;
291
- let newPath = 'local-attachments/file-';
292
- var createResponse = function createResponse(adjuntoRow) {
293
- let resultado = {
294
- message: 'La subida se realizó correctamente (update)',
295
- nombre: adjuntoRow.nombre,
296
- nombre_original: adjuntoRow.nombre_original,
297
- ext: adjuntoRow.ext,
298
- fecha: adjuntoRow.fecha,
299
- hora: adjuntoRow.hora,
300
- id_adjunto: adjuntoRow.id_adjunto
301
- };
302
- return resultado;
303
- };
304
- var moveFile = function moveFile(file, id_adjunto, extension) {
305
- fs_1.promises.move(file.path, newPath + id_adjunto + '.' + extension, { overwrite: true });
306
- };
307
- return Promise.resolve().then(function () {
308
- if (parameters.id_adjunto) {
267
+ where hay.id_caso is null`, [OPERATIVO, parameters.annio, parameters.mes, parameters.lote]).fetchAll();
268
+ var params = { operativo: OPERATIVO };
269
+ for (var i = 0; i < result.rowCount; i++) {
270
+ await be.procedure.caso_guardar.coreFunction(context, (0, best_globals_1.changing)(params, { id_caso: result.rows[i].id_caso, datos_caso: (0, best_globals_1.changing)(contenedorVacio, { id: result.rows[i].id }) }));
271
+ }
272
+ return { agregadas: result.rowCount };
273
+ }
274
+ },
275
+ {
276
+ action: 'upload_file',
277
+ progress: true,
278
+ parameters: [
279
+ { name: 'id_adjunto', typeName: 'integer' },
280
+ { name: 'nombre', typeName: 'text' },
281
+ ],
282
+ files: { count: 1 },
283
+ coreFunction: function (context, parameters, files) {
284
+ let be = context.be;
285
+ let client = context.client;
286
+ context.informProgress({ message: be.messages.fileUploaded });
287
+ let file = files[0];
288
+ let ext = path.extname(file.path).substr(1);
289
+ let originalFilename = file.originalFilename.slice(0, -(ext.length + 1));
290
+ let filename = parameters.nombre || originalFilename;
291
+ let newPath = 'local-attachments/file-';
292
+ var createResponse = function createResponse(adjuntoRow) {
293
+ let resultado = {
294
+ message: 'La subida se realizó correctamente (update)',
295
+ nombre: adjuntoRow.nombre,
296
+ nombre_original: adjuntoRow.nombre_original,
297
+ ext: adjuntoRow.ext,
298
+ fecha: adjuntoRow.fecha,
299
+ hora: adjuntoRow.hora,
300
+ id_adjunto: adjuntoRow.id_adjunto
301
+ };
302
+ return resultado;
303
+ };
304
+ var moveFile = function moveFile(file, id_adjunto, extension) {
305
+ fs_1.promises.move(file.path, newPath + id_adjunto + '.' + extension, { overwrite: true });
306
+ };
307
+ return Promise.resolve().then(function () {
308
+ if (parameters.id_adjunto) {
309
309
  return context.client.query(`update adjuntos set nombre= $1,nombre_original = $2, ext = $3, ruta = concat('local-attachments/file-',$4::text,'.',$3::text), fecha = now(), hora = date_trunc('seconds',current_timestamp-current_date)
310
- where id_adjunto = $4 returning *`, [filename, originalFilename, ext, parameters.id_adjunto]).fetchUniqueRow().then(function (result) {
311
- return createResponse(result.row);
312
- }).then(function (resultado) {
313
- moveFile(file, resultado.id_adjunto, resultado.ext);
314
- return resultado;
315
- });
316
- }
317
- else {
318
- return context.client.query(`insert into adjuntos (nombre, nombre_original, ext, fecha, hora) values ($1,$2,$3,now(), date_trunc('seconds',current_timestamp-current_date)) returning *`, [filename, originalFilename, ext]).fetchUniqueRow().then(function (result) {
310
+ where id_adjunto = $4 returning *`, [filename, originalFilename, ext, parameters.id_adjunto]).fetchUniqueRow().then(function (result) {
311
+ return createResponse(result.row);
312
+ }).then(function (resultado) {
313
+ moveFile(file, resultado.id_adjunto, resultado.ext);
314
+ return resultado;
315
+ });
316
+ }
317
+ else {
318
+ return context.client.query(`insert into adjuntos (nombre, nombre_original, ext, fecha, hora) values ($1,$2,$3,now(), date_trunc('seconds',current_timestamp-current_date)) returning *`, [filename, originalFilename, ext]).fetchUniqueRow().then(function (result) {
319
319
  return context.client.query(`update adjuntos set ruta = concat('local-attachments/file-',id_adjunto::text,'.',ext)
320
- where id_adjunto = $1 returning *`, [result.row.id_adjunto]).fetchUniqueRow().then(function (result) {
321
- return createResponse(result.row);
322
- }).then(function (resultado) {
323
- moveFile(file, resultado.id_adjunto, resultado.ext);
324
- return resultado;
325
- });
326
- });
327
- }
328
- }).catch(function (err) {
329
- throw err;
330
- });
331
- }
332
- },
333
- {
334
- action: 'caso_guardar',
335
- parameters: [
336
- { name: 'operativo', typeName: 'text', references: 'operativos' },
337
- { name: 'id_caso', typeName: 'text' },
338
- { name: 'datos_caso', typeName: 'jsonb' },
339
- ],
340
- definedIn: 'dmencu',
341
- //@ts-ignore especifico el tipo de los parámetros
342
- coreFunction: async function (context, parameters, newClient) {
343
- var client = newClient || context.client;
344
- var datos_json = parameters.datos_caso;
345
- var be = context.be;
346
- var tableStructures_app = be.tableStructures;
347
- var struct_dmencu = createStructure(context, MAIN_TABLENAME);
348
- datos_json['operativo'] = parameters.operativo;
349
- //TODO : vivienda ó enc???
350
- datos_json['vivienda'] = parameters.id_caso;
351
- function completar_ult_pk_en_arr(ult_pk, ua_arr) {
352
- var con_pk_completa = ua_arr;
353
- if (ua_arr && ua_arr.length >= 1) {
354
- con_pk_completa = con_pk_completa.map((una_ua, i) => {
355
- una_ua[ult_pk] = i + 1;
356
- return una_ua;
357
- });
358
- }
359
- ;
360
- return con_pk_completa;
361
- }
362
- for (var key1 in datos_json) {
363
- var dato_key1 = datos_json[key1];
364
- if (dato_key1 instanceof Array && dato_key1.length >= 1) {
365
- var pk1 = tableStructures_app[key1](context).primaryKey;
366
- var ult_pk1 = pk1[pk1.length - 1];
367
- datos_json[key1] = completar_ult_pk_en_arr(ult_pk1, datos_json[key1]);
368
- datos_json[key1].forEach((un_key1, i1) => {
369
- for (var key2 in un_key1) {
370
- if (un_key1[key2] instanceof Array && un_key1[key2].length >= 1) {
371
- var pk2 = tableStructures_app[key2](context).primaryKey;
372
- var ult_pk2 = pk2[pk2.length - 1];
373
- datos_json[key1][i1][key2] = completar_ult_pk_en_arr(ult_pk2, datos_json[key1][i1][key2]);
374
- datos_json[key1][i1][key2].forEach(un_key2 => {
375
- Object.keys(un_key2).filter(p2 => p2.startsWith('$')).forEach(pp2 => delete un_key2[pp2]);
376
- });
377
- }
378
- if (key2.startsWith('$') || key2.startsWith('_')) {
379
- delete datos_json[key1][i1][key2];
380
- }
381
- }
382
- });
383
- }
384
- if (key1.startsWith('$')) {
385
- delete datos_json[key1];
386
- }
387
- ;
388
- }
389
- delete datos_json.codRea;
390
- delete datos_json.codNoRea;
391
- delete datos_json.resumenEstado;
392
- delete datos_json.codReaSup;
393
- delete datos_json.codNoReaSup;
394
- delete datos_json.resumenEstadoSup;
395
- if (Object.keys(datos_json).length > 2) {
396
- var queries = sqlTools.structuredData.sqlWrite(datos_json, struct_dmencu);
397
- return await queries.reduce(function (promise, query) {
398
- return promise.then(function () {
399
- return client.query(query).execute().then(function (result) {
400
- return 'ok';
401
- });
402
- });
403
- }, Promise.resolve()).then(function () {
404
- return "ok";
405
- }).catch(function (err) {
406
- console.log("caso_guardar ENTRA EN EL CATCH: ", err);
407
- throw err;
408
- });
409
- }
410
- else {
411
- return 'vacio';
412
- }
413
- }
414
- },
415
- {
416
- action: 'caso_traer',
417
- parameters: [
418
- //{name:'formulario' , typeName:'text'},
419
- { name: 'operativo', references: 'operativos', typeName: 'text' },
420
- { name: 'id_caso', typeName: 'text' },
421
- ],
422
- resultOk: 'goToEnc',
423
- definedIn: 'dmencu',
424
- coreFunction: async function (context, parameters) {
425
- var client = context.client;
426
- var struct_dmencu = createStructure(context, MAIN_TABLENAME);
427
- var sql = sqlTools.structuredData.sqlRead({ operativo: parameters.operativo, vivienda: parameters.id_caso }, struct_dmencu);
428
- var result = await client.query(sql).fetchUniqueValue();
429
- var response = {
430
- operativo: parameters.operativo,
431
- vivienda: parameters.id_caso,
432
- datos_caso: result.value,
433
- //formulario: formPrincipal,
434
- };
435
- return response;
436
- }
437
- },
438
- {
439
- action: 'caso_traer_o_crear',
440
- parameters: [
441
- { name: 'operativo', references: 'operativos', typeName: 'text' },
442
- { name: 'id_caso', typeName: 'text' },
443
- ],
444
- resultOk: 'goToEnc',
445
- // bitacora:{always:true},
446
- coreFunction: async function (context, parameters) {
447
- var be = context.be;
448
- try {
449
- var result = await be.procedure['caso_traer'].coreFunction(context, parameters);
450
- return result;
451
- }
452
- catch (err) {
453
- var json = await be.procedure['caso_preparar'].coreFunction(context, parameters);
454
- await be.procedure['caso_guardar'].coreFunction(context, (0, best_globals_1.changing)(parameters, { datos_caso: json }));
455
- return await be.procedure['caso_traer'].coreFunction(context, parameters);
456
- }
457
- }
458
- },
459
- {
460
- action: 'pasar_json2ua',
461
- parameters: [],
462
- coreFunction: async function (context, _parameters) {
463
- /* GENERALIZAR: */
464
- var be = context.be;
465
- /* FIN-GENERALIZAR: */
466
- const OPERATIVO = await (0, exports.getOperativoActual)(context);
467
- let resultMain = await context.client.query(`SELECT * FROM ${MAIN_TABLENAME} LIMIT 1`).fetchAll();
468
- if (resultMain.rowCount > 0) {
469
- console.log('HAY DATOS', resultMain.rows);
470
- throw new Error('HAY DATOS. NO SE PUEDE INICIAR EL PASAJE');
471
- }
320
+ where id_adjunto = $1 returning *`, [result.row.id_adjunto]).fetchUniqueRow().then(function (result) {
321
+ return createResponse(result.row);
322
+ }).then(function (resultado) {
323
+ moveFile(file, resultado.id_adjunto, resultado.ext);
324
+ return resultado;
325
+ });
326
+ });
327
+ }
328
+ }).catch(function (err) {
329
+ throw err;
330
+ });
331
+ }
332
+ },
333
+ {
334
+ action: 'caso_guardar',
335
+ parameters: [
336
+ { name: 'operativo', typeName: 'text', references: 'operativos' },
337
+ { name: 'id_caso', typeName: 'text' },
338
+ { name: 'datos_caso', typeName: 'jsonb' },
339
+ ],
340
+ definedIn: 'dmencu',
341
+ //@ts-ignore especifico el tipo de los parámetros
342
+ coreFunction: async function (context, parameters, newClient) {
343
+ var client = newClient || context.client;
344
+ var datos_json = parameters.datos_caso;
345
+ var be = context.be;
346
+ var tableStructures_app = be.tableStructures;
347
+ var struct_dmencu = createStructure(context, MAIN_TABLENAME);
348
+ datos_json['operativo'] = parameters.operativo;
349
+ //TODO : vivienda ó enc???
350
+ datos_json['vivienda'] = parameters.id_caso;
351
+ function completar_ult_pk_en_arr(ult_pk, ua_arr) {
352
+ var con_pk_completa = ua_arr;
353
+ if (ua_arr && ua_arr.length >= 1) {
354
+ con_pk_completa = con_pk_completa.map((una_ua, i) => {
355
+ una_ua[ult_pk] = i + 1;
356
+ return una_ua;
357
+ });
358
+ }
359
+ ;
360
+ return con_pk_completa;
361
+ }
362
+ for (var key1 in datos_json) {
363
+ var dato_key1 = datos_json[key1];
364
+ if (dato_key1 instanceof Array && dato_key1.length >= 1) {
365
+ var pk1 = tableStructures_app[key1](context).primaryKey;
366
+ var ult_pk1 = pk1[pk1.length - 1];
367
+ datos_json[key1] = completar_ult_pk_en_arr(ult_pk1, datos_json[key1]);
368
+ datos_json[key1].forEach((un_key1, i1) => {
369
+ for (var key2 in un_key1) {
370
+ if (un_key1[key2] instanceof Array && un_key1[key2].length >= 1) {
371
+ var pk2 = tableStructures_app[key2](context).primaryKey;
372
+ var ult_pk2 = pk2[pk2.length - 1];
373
+ datos_json[key1][i1][key2] = completar_ult_pk_en_arr(ult_pk2, datos_json[key1][i1][key2]);
374
+ datos_json[key1][i1][key2].forEach(un_key2 => {
375
+ Object.keys(un_key2).filter(p2 => p2.startsWith('$')).forEach(pp2 => delete un_key2[pp2]);
376
+ });
377
+ }
378
+ if (key2.startsWith('$') || key2.startsWith('_')) {
379
+ delete datos_json[key1][i1][key2];
380
+ }
381
+ }
382
+ });
383
+ }
384
+ if (key1.startsWith('$')) {
385
+ delete datos_json[key1];
386
+ }
387
+ ;
388
+ }
389
+ delete datos_json.codRea;
390
+ delete datos_json.codNoRea;
391
+ delete datos_json.resumenEstado;
392
+ delete datos_json.codReaSup;
393
+ delete datos_json.codNoReaSup;
394
+ delete datos_json.resumenEstadoSup;
395
+ if (Object.keys(datos_json).length > 2) {
396
+ var queries = sqlTools.structuredData.sqlWrite(datos_json, struct_dmencu);
397
+ return await queries.reduce(function (promise, query) {
398
+ return promise.then(function () {
399
+ return client.query(query).execute().then(function (result) {
400
+ return 'ok';
401
+ });
402
+ });
403
+ }, Promise.resolve()).then(function () {
404
+ return "ok";
405
+ }).catch(function (err) {
406
+ console.log("caso_guardar ENTRA EN EL CATCH: ", err);
407
+ throw err;
408
+ });
409
+ }
410
+ else {
411
+ return 'vacio';
412
+ }
413
+ }
414
+ },
415
+ {
416
+ action: 'caso_traer',
417
+ parameters: [
418
+ //{name:'formulario' , typeName:'text'},
419
+ { name: 'operativo', references: 'operativos', typeName: 'text' },
420
+ { name: 'id_caso', typeName: 'text' },
421
+ ],
422
+ resultOk: 'goToEnc',
423
+ definedIn: 'dmencu',
424
+ coreFunction: async function (context, parameters) {
425
+ var client = context.client;
426
+ var struct_dmencu = createStructure(context, MAIN_TABLENAME);
427
+ var sql = sqlTools.structuredData.sqlRead({ operativo: parameters.operativo, vivienda: parameters.id_caso }, struct_dmencu);
428
+ var result = await client.query(sql).fetchUniqueValue();
429
+ var response = {
430
+ operativo: parameters.operativo,
431
+ vivienda: parameters.id_caso,
432
+ datos_caso: result.value,
433
+ //formulario: formPrincipal,
434
+ };
435
+ return response;
436
+ }
437
+ },
438
+ {
439
+ action: 'caso_traer_o_crear',
440
+ parameters: [
441
+ { name: 'operativo', references: 'operativos', typeName: 'text' },
442
+ { name: 'id_caso', typeName: 'text' },
443
+ ],
444
+ resultOk: 'goToEnc',
445
+ // bitacora:{always:true},
446
+ coreFunction: async function (context, parameters) {
447
+ var be = context.be;
448
+ try {
449
+ var result = await be.procedure['caso_traer'].coreFunction(context, parameters);
450
+ return result;
451
+ }
452
+ catch (err) {
453
+ var json = await be.procedure['caso_preparar'].coreFunction(context, parameters);
454
+ await be.procedure['caso_guardar'].coreFunction(context, (0, best_globals_1.changing)(parameters, { datos_caso: json }));
455
+ return await be.procedure['caso_traer'].coreFunction(context, parameters);
456
+ }
457
+ }
458
+ },
459
+ {
460
+ action: 'pasar_json2ua',
461
+ parameters: [],
462
+ coreFunction: async function (context, _parameters) {
463
+ /* GENERALIZAR: */
464
+ var be = context.be;
465
+ /* FIN-GENERALIZAR: */
466
+ const OPERATIVO = await (0, exports.getOperativoActual)(context);
467
+ let resultMain = await context.client.query(`SELECT * FROM ${MAIN_TABLENAME} LIMIT 1`).fetchAll();
468
+ if (resultMain.rowCount > 0) {
469
+ console.log('HAY DATOS', resultMain.rows);
470
+ throw new Error('HAY DATOS. NO SE PUEDE INICIAR EL PASAJE');
471
+ }
472
472
  let resultJson = await context.client.query(`SELECT operativo, enc id_caso, json_encuesta datos_caso from tem
473
473
  WHERE operativo=$1 and resumen_estado is distinct from 'vacio' and json_encuesta is not null
474
- order by enc `, [OPERATIVO]).fetchAll();
475
- var procedureGuardar = be.procedure.caso_guardar;
476
- if (procedureGuardar.definedIn != 'dmencu') {
477
- throw new Error('hay que sobreescribir caso_guardar');
478
- }
479
- return Promise.all(resultJson.rows.map(async function (row) {
480
- let resultado = `id caso ${row.id_caso}: `;
481
- try {
482
- await be.inTransaction(null, async function (client) {
483
- resultado += await procedureGuardar.coreFunction(context, row, client);
484
- });
485
- }
486
- catch (err) {
487
- let errMessage = resultado + "json2ua error. " + err;
488
- resultado = errMessage;
489
- console.log(errMessage);
490
- }
491
- if (resultado.includes('ok')) {
492
- var { datos_caso, vivienda, operativo } = await be.procedure.caso_traer.coreFunction(context, { operativo: row.operativo, id_caso: row.id_caso });
493
- var verQueGrabo = { datos_caso, vivienda, operativo };
494
- try {
495
- discrepances.showAndThrow(verQueGrabo, row);
496
- }
497
- catch (err) {
498
- console.log(verQueGrabo, row);
499
- }
500
- }
501
- return resultado;
502
- })).catch(function (err) {
503
- throw err;
504
- }).then(function (result) {
505
- return result;
506
- });
507
- }
508
- },
509
- {
510
- action: 'dm_forpkraiz_cargar',
511
- parameters: [
512
- { name: 'operativo', typeName: 'text' },
513
- { name: 'vivienda', typeName: 'text' },
514
- { name: 'tarea', typeName: 'text', references: "tareas" },
515
- ],
516
- coreFunction: async function (context, parameters) {
517
- var be = context.be;
518
- var { operativo, vivienda, tarea } = parameters;
474
+ order by enc `, [OPERATIVO]).fetchAll();
475
+ var procedureGuardar = be.procedure.caso_guardar;
476
+ if (procedureGuardar.definedIn != 'dmencu') {
477
+ throw new Error('hay que sobreescribir caso_guardar');
478
+ }
479
+ return Promise.all(resultJson.rows.map(async function (row) {
480
+ let resultado = `id caso ${row.id_caso}: `;
481
+ try {
482
+ await be.inTransaction(null, async function (client) {
483
+ resultado += await procedureGuardar.coreFunction(context, row, client);
484
+ });
485
+ }
486
+ catch (err) {
487
+ let errMessage = resultado + "json2ua error. " + err;
488
+ resultado = errMessage;
489
+ console.log(errMessage);
490
+ }
491
+ if (resultado.includes('ok')) {
492
+ var { datos_caso, vivienda, operativo } = await be.procedure.caso_traer.coreFunction(context, { operativo: row.operativo, id_caso: row.id_caso });
493
+ var verQueGrabo = { datos_caso, vivienda, operativo };
494
+ try {
495
+ discrepances.showAndThrow(verQueGrabo, row);
496
+ }
497
+ catch (err) {
498
+ console.log(verQueGrabo, row);
499
+ }
500
+ }
501
+ return resultado;
502
+ })).catch(function (err) {
503
+ throw err;
504
+ }).then(function (result) {
505
+ return result;
506
+ });
507
+ }
508
+ },
509
+ {
510
+ action: 'dm_forpkraiz_cargar',
511
+ parameters: [
512
+ { name: 'operativo', typeName: 'text' },
513
+ { name: 'vivienda', typeName: 'text' },
514
+ { name: 'tarea', typeName: 'text', references: "tareas" },
515
+ ],
516
+ coreFunction: async function (context, parameters) {
517
+ var be = context.be;
518
+ var { operativo, vivienda, tarea } = parameters;
519
519
  var main_form = (await context.client.query(`select main_form
520
520
  from tareas
521
- where operativo= $1 and tarea=$2`, [operativo, tarea]).fetchUniqueValue()).value;
522
- var condviv = ` t.operativo= $1 and t.enc =$2`;
521
+ where operativo= $1 and tarea=$2`, [operativo, tarea]).fetchUniqueValue()).value;
522
+ var condviv = ` t.operativo= $1 and t.enc =$2`;
523
523
  var soloLectura = !!(await context.client.query(`select *
524
- from tareas_tem
525
- where operativo= $1 and enc = $2 and cargado_dm is not null`, [operativo, vivienda]).fetchOneRowIfExists()).rowCount;
526
- var { row } = await context.client.query(getHdrQuery(condviv), [operativo, vivienda]).fetchUniqueRow();
527
- row.informacionHdr[vivienda].tarea = {
528
- tarea,
529
- main_form
530
- };
531
- return {
532
- ...row,
533
- operativo,
534
- soloLectura,
535
- idPer: context.user.idper,
536
- cargas: likeAr.createIndex(row.cargas.map(carga => ({ ...carga, fecha: carga.fecha ? best_globals_1.date.iso(carga.fecha).toDmy() : null })), 'carga'),
537
- timestampEstructura: be.timestampEstructura
538
- };
539
- }
540
- },
541
- {
542
- action: 'dm_forpkraiz_descargar',
543
- parameters: [
544
- { name: 'operativo', typeName: 'text' },
545
- { name: 'persistentes', typeName: 'jsonb' },
546
- ],
547
- coreFunction: async function (context, parameters) {
548
- var be = context.be;
549
- var { operativo, persistentes } = parameters;
550
- const UA_PRINCIPAL = await getUAPrincipal(context.client, operativo);
551
- await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal, idEnc) => {
552
- if (respuestasUAPrincipal.s1a1_obs == '!prueba de error al grabar!') {
553
- throw new Error('DIO PRUEBA DE ERROR AL GRABAR');
554
- }
555
- var { params, setters } = await getParametersAndSettersForUpdateTem(context, operativo, idEnc, respuestasUAPrincipal, persistentes.informacionHdr[idEnc].tarea.tarea);
524
+ from tareas_tem join estados using (operativo, estado) --pk estado verificada
525
+ where operativo= $1 and enc = $2 and (cargado_dm is not null or not permite_editar_encuesta)`, [operativo, vivienda]).fetchOneRowIfExists()).rowCount;
526
+ var { row } = await context.client.query(getHdrQuery(condviv), [operativo, vivienda]).fetchUniqueRow();
527
+ row.informacionHdr[vivienda].tarea = {
528
+ tarea,
529
+ main_form
530
+ };
531
+ return {
532
+ ...row,
533
+ operativo,
534
+ soloLectura,
535
+ idPer: context.user.idper,
536
+ cargas: likeAr.createIndex(row.cargas.map(carga => ({ ...carga, fecha: carga.fecha ? best_globals_1.date.iso(carga.fecha).toDmy() : null })), 'carga'),
537
+ timestampEstructura: be.timestampEstructura
538
+ };
539
+ }
540
+ },
541
+ {
542
+ action: 'dm_forpkraiz_descargar',
543
+ parameters: [
544
+ { name: 'operativo', typeName: 'text' },
545
+ { name: 'persistentes', typeName: 'jsonb' },
546
+ ],
547
+ coreFunction: async function (context, parameters) {
548
+ var be = context.be;
549
+ var { operativo, persistentes } = parameters;
550
+ const UA_PRINCIPAL = await getUAPrincipal(context.client, operativo);
551
+ await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal, idEnc) => {
552
+ if (respuestasUAPrincipal.s1a1_obs == '!prueba de error al grabar!') {
553
+ throw new Error('DIO PRUEBA DE ERROR AL GRABAR');
554
+ }
555
+ var { params, setters } = await getParametersAndSettersForUpdateTem(context, operativo, idEnc, respuestasUAPrincipal, persistentes.informacionHdr[idEnc].tarea.tarea);
556
556
  await context.client.query(`update tem
557
557
  set ${setters}
558
558
  where operativo= $1 and enc = $2
559
- returning 'ok'`, params).fetchUniqueRow();
560
- //guardar paralelamente en tablas ua
561
- var procedureGuardar = be.procedure.caso_guardar;
562
- let resultado = `id enc ${idEnc}: `;
563
- let param_guardar = { operativo: operativo, id_caso: idEnc, datos_caso: respuestasUAPrincipal };
564
- let errMessage;
565
- try {
566
- await be.inTransaction(null, async function (client) {
567
- resultado += await procedureGuardar.coreFunction(context, param_guardar, client);
568
- });
569
- }
570
- catch (err) {
571
- errMessage = resultado + "dm_forpkraiz_descargar. " + err;
572
- resultado = errMessage;
573
- console.log(errMessage);
574
- }
559
+ returning 'ok'`, params).fetchUniqueRow();
560
+ //guardar paralelamente en tablas ua
561
+ var procedureGuardar = be.procedure.caso_guardar;
562
+ let resultado = `id enc ${idEnc}: `;
563
+ let param_guardar = { operativo: operativo, id_caso: idEnc, datos_caso: respuestasUAPrincipal };
564
+ let errMessage;
565
+ try {
566
+ await be.inTransaction(null, async function (client) {
567
+ resultado += await procedureGuardar.coreFunction(context, param_guardar, client);
568
+ });
569
+ }
570
+ catch (err) {
571
+ errMessage = resultado + "dm_forpkraiz_descargar. " + err;
572
+ resultado = errMessage;
573
+ console.log(errMessage);
574
+ }
575
575
  await context.client.query(`update tem
576
576
  set pase_tabla= $3
577
577
  where operativo= $1 and enc = $2
578
- returning 'ok'`, [operativo, idEnc, resultado]).fetchUniqueRow();
579
- }).array());
580
- return 'ok';
581
- }
582
- },
583
- {
584
- action: 'dm_sincronizar',
585
- parameters: [
586
- { name: 'persistentes', typeName: 'jsonb' },
587
- ],
588
- coreFunction: async function (context, parameters) {
589
- const OPERATIVO = await (0, exports.getOperativoActual)(context);
590
- const ESTADO_POSTERIOR_CARGA = 'C';
591
- const ESTADO_POSTERIOR_DESCARGA = 'D';
592
- var be = context.be;
593
- var { persistentes } = parameters;
594
- var num_sincro = 0;
595
- var token = persistentes === null || persistentes === void 0 ? void 0 : persistentes.token;
596
- if (!token) {
597
- token = (await be.procedure.token_get.coreFunction(context, {
598
- useragent: context.session.req.useragent,
599
- username: context.username
600
- })).token;
601
- }
578
+ returning 'ok'`, [operativo, idEnc, resultado]).fetchUniqueRow();
579
+ }).array());
580
+ return 'ok';
581
+ }
582
+ },
583
+ {
584
+ action: 'dm_sincronizar',
585
+ parameters: [
586
+ { name: 'persistentes', typeName: 'jsonb' },
587
+ ],
588
+ coreFunction: async function (context, parameters) {
589
+ const OPERATIVO = await (0, exports.getOperativoActual)(context);
590
+ const ESTADO_POSTERIOR_CARGA = 'C';
591
+ const ESTADO_POSTERIOR_DESCARGA = 'D';
592
+ var be = context.be;
593
+ var { persistentes } = parameters;
594
+ var num_sincro = 0;
595
+ var token = persistentes === null || persistentes === void 0 ? void 0 : persistentes.token;
596
+ if (!token) {
597
+ token = (await be.procedure.token_get.coreFunction(context, {
598
+ useragent: context.session.req.useragent,
599
+ username: context.username
600
+ })).token;
601
+ }
602
602
  var { value } = await context.client.query(`
603
603
  INSERT INTO sincronizaciones (token, usuario, datos)
604
604
  VALUES ($1,$2,$3)
605
605
  RETURNING sincro
606
- `, [token, context.username, persistentes]).fetchUniqueValue();
607
- num_sincro = value;
606
+ `, [token, context.username, persistentes]).fetchUniqueValue();
607
+ num_sincro = value;
608
608
  var condviv = `
609
609
  tt.operativo= $1
610
610
  and asignado = $2
611
611
  and tt.operacion='cargar'
612
612
  and (tt.cargado_dm is null or tt.cargado_dm = ${context.be.db.quoteLiteral(token)})
613
- `;
614
- const UA_PRINCIPAL = await getUAPrincipal(context.client, OPERATIVO);
615
- if (persistentes) {
616
- await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal, idEnc) => {
617
- var tarea = persistentes.informacionHdr[idEnc].tarea.tarea;
618
- var puedoGuardarEnTEM = true;
619
- //TODO GENERALIZAR EL HORROR ESTE
620
- var setters = ``;
621
- var params = [OPERATIVO, idEnc, tarea, token];
622
- if (tarea == 'supe') {
623
- setters += `, resumen_estado_sup=$5, norea_sup=$6, rea_sup=$7`;
624
- params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);
625
- }
626
- else {
627
- setters += `, resumen_estado=$5, norea=$6, rea=$7`;
628
- params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);
629
- }
613
+ `;
614
+ const UA_PRINCIPAL = await getUAPrincipal(context.client, OPERATIVO);
615
+ if (persistentes) {
616
+ await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal, idEnc) => {
617
+ var tarea = persistentes.informacionHdr[idEnc].tarea.tarea;
618
+ var puedoGuardarEnTEM = true;
619
+ //TODO GENERALIZAR EL HORROR ESTE
620
+ var setters = ``;
621
+ var params = [OPERATIVO, idEnc, tarea, token];
622
+ if (tarea == 'supe') {
623
+ setters += `, resumen_estado_sup=$5, norea_sup=$6, rea_sup=$7`;
624
+ params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);
625
+ }
626
+ else {
627
+ setters += `, resumen_estado=$5, norea=$6, rea=$7`;
628
+ params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);
629
+ }
630
630
  var queryTareasTem = await context.client.query(`update tareas_tem
631
631
  set estado = ${context.be.db.quoteLiteral(ESTADO_POSTERIOR_DESCARGA)}, cargado_dm=null ${setters}
632
632
  where operativo= $1 and enc = $2 and tarea = $3 and cargado_dm = $4
633
- returning 'ok'`, params).fetchOneRowIfExists();
634
- puedoGuardarEnTEM = queryTareasTem.rowCount == 1;
635
- if (puedoGuardarEnTEM) {
636
- var { params, setters } = await getParametersAndSettersForUpdateTem(context, OPERATIVO, idEnc, respuestasUAPrincipal, tarea);
633
+ returning 'ok'`, params).fetchOneRowIfExists();
634
+ puedoGuardarEnTEM = queryTareasTem.rowCount == 1;
635
+ if (puedoGuardarEnTEM) {
636
+ var { params, setters } = await getParametersAndSettersForUpdateTem(context, OPERATIVO, idEnc, respuestasUAPrincipal, tarea);
637
637
  await context.client.query(`update tem
638
638
  set ${setters}
639
639
  where operativo= $1 and enc = $2
640
- returning 'ok'`, params).fetchUniqueRow();
641
- //guardar paralelamente en tablas ua
642
- var procedureGuardar = be.procedure.caso_guardar;
643
- let resultado = `id enc ${idEnc}: `;
644
- let param_guardar = { operativo: OPERATIVO, id_caso: idEnc, datos_caso: respuestasUAPrincipal };
645
- let errMessage;
646
- try {
647
- await be.inTransaction(null, async function (client) {
648
- resultado += await procedureGuardar.coreFunction(context, param_guardar, client);
649
- });
650
- }
651
- catch (err) {
652
- errMessage = resultado + "dm_forpkraiz_descargar. " + err;
653
- resultado = errMessage;
654
- console.log(errMessage);
655
- }
640
+ returning 'ok'`, params).fetchUniqueRow();
641
+ //guardar paralelamente en tablas ua
642
+ var procedureGuardar = be.procedure.caso_guardar;
643
+ let resultado = `id enc ${idEnc}: `;
644
+ let param_guardar = { operativo: OPERATIVO, id_caso: idEnc, datos_caso: respuestasUAPrincipal };
645
+ let errMessage;
646
+ try {
647
+ await be.inTransaction(null, async function (client) {
648
+ resultado += await procedureGuardar.coreFunction(context, param_guardar, client);
649
+ });
650
+ }
651
+ catch (err) {
652
+ errMessage = resultado + "dm_forpkraiz_descargar. " + err;
653
+ resultado = errMessage;
654
+ console.log(errMessage);
655
+ }
656
656
  await context.client.query(`update tem
657
657
  set pase_tabla= $3
658
658
  where operativo= $1 and enc = $2
659
- returning 'ok'`, [OPERATIVO, idEnc, resultado]).fetchUniqueRow();
660
- }
661
- else {
662
- await fs_1.promises.appendFile('local-recibido-sin-token.txt', JSON.stringify({ now: new Date(), user: context.username, idCaso: idEnc, vivienda: respuestasUAPrincipal }) + '\n\n', 'utf8');
663
- }
664
- }).array());
665
- }
666
- console.log("condviv: ", condviv);
667
- console.log("query: ", getHdrQuery(condviv));
668
- var { row } = await context.client.query(getHdrQuery(condviv), [OPERATIVO, context.user.idper]).fetchUniqueRow();
669
- // console.log('xxxxxxxxxxxxxxxxxxxxxxxxxxx',getHdrQuery(condviv));
659
+ returning 'ok'`, [OPERATIVO, idEnc, resultado]).fetchUniqueRow();
660
+ }
661
+ else {
662
+ await fs_1.promises.appendFile('local-recibido-sin-token.txt', JSON.stringify({ now: new Date(), user: context.username, idCaso: idEnc, vivienda: respuestasUAPrincipal }) + '\n\n', 'utf8');
663
+ }
664
+ }).array());
665
+ }
666
+ console.log("condviv: ", condviv);
667
+ console.log("query: ", getHdrQuery(condviv));
668
+ var { row } = await context.client.query(getHdrQuery(condviv), [OPERATIVO, context.user.idper]).fetchUniqueRow();
669
+ // console.log('xxxxxxxxxxxxxxxxxxxxxxxxxxx',getHdrQuery(condviv));
670
670
  await context.client.query(`update tareas_tem tt
671
671
  set estado = $4, cargado_dm=$3::text
672
672
  where ${condviv}
673
- returning enc`, [OPERATIVO, parameters.enc ? parameters.enc : context.user.idper, token, ESTADO_POSTERIOR_CARGA]).fetchAll();
674
- return {
675
- ...row,
676
- operativo: OPERATIVO,
677
- soloLectura: false,
678
- token,
679
- num_sincro,
680
- idper: context.user.idper,
681
- cargas: likeAr.createIndex(row.cargas.map(carga => ({ ...carga, fecha: carga.fecha ? best_globals_1.date.iso(carga.fecha).toDmy() : null, estado_carga: 'relevamiento' })), 'carga')
682
- };
683
- }
684
- },
685
- {
686
- action: 'dm_backup',
687
- parameters: [
688
- { name: 'token', typeName: 'text' },
689
- { name: 'tem', typeName: 'jsonb' },
690
- ],
691
- unlogged: true,
692
- coreFunction: async function (context, parameters) {
693
- var { be, client } = context;
694
- const OPERATIVO = await (0, exports.getOperativoActual)(context);
695
- var num_sincro = 0;
696
- var token = parameters.token;
697
- if (token == null) {
698
- return { ok: 'ok:N/T' };
699
- }
700
- else {
701
- var { rowCount } = await client.query(`select 1 from tokens where token = $1`, [token]).fetchOneRowIfExists();
702
- if (!rowCount) {
703
- return { ok: 'ok:N/T' };
704
- }
705
- }
706
- if (parameters.tem) {
707
- await Promise.all(likeAr(parameters.tem).map(async (backup) => {
673
+ returning enc`, [OPERATIVO, parameters.enc ? parameters.enc : context.user.idper, token, ESTADO_POSTERIOR_CARGA]).fetchAll();
674
+ return {
675
+ ...row,
676
+ operativo: OPERATIVO,
677
+ soloLectura: false,
678
+ token,
679
+ num_sincro,
680
+ idper: context.user.idper,
681
+ cargas: likeAr.createIndex(row.cargas.map(carga => ({ ...carga, fecha: carga.fecha ? best_globals_1.date.iso(carga.fecha).toDmy() : null, estado_carga: 'relevamiento' })), 'carga')
682
+ };
683
+ }
684
+ },
685
+ {
686
+ action: 'dm_backup',
687
+ parameters: [
688
+ { name: 'token', typeName: 'text' },
689
+ { name: 'tem', typeName: 'jsonb' },
690
+ ],
691
+ unlogged: true,
692
+ coreFunction: async function (context, parameters) {
693
+ var { be, client } = context;
694
+ const OPERATIVO = await (0, exports.getOperativoActual)(context);
695
+ var num_sincro = 0;
696
+ var token = parameters.token;
697
+ if (token == null) {
698
+ return { ok: 'ok:N/T' };
699
+ }
700
+ else {
701
+ var { rowCount } = await client.query(`select 1 from tokens where token = $1`, [token]).fetchOneRowIfExists();
702
+ if (!rowCount) {
703
+ return { ok: 'ok:N/T' };
704
+ }
705
+ }
706
+ if (parameters.tem) {
707
+ await Promise.all(likeAr(parameters.tem).map(async (backup) => {
708
708
  context.client.query(`update tem
709
709
  set json_backup = $3
710
710
  where operativo= $1 and enc = $2 and json_backup is distinct from $4
711
- returning 'ok'`, [OPERATIVO, backup.forPkRaiz.vivienda, backup.respuestasRaiz, backup.respuestasRaiz]).fetchOneRowIfExists();
712
- }).array());
713
- }
714
- return {
715
- ok: 'ok'
716
- };
717
- }
718
- },
719
- {
720
- action: 'consistir_vivienda',
721
- parameters: [
722
- { name: 'operativo', references: 'operativos', typeName: 'text' },
723
- { name: 'vivienda', typeName: 'text' },
724
- ],
725
- coreFunction: async function (context, parameters) {
726
- var { be, client } = context;
727
- let param_proc = {
728
- operativo: parameters.operativo,
729
- id_caso: parameters.vivienda
730
- };
731
- let errMessage;
732
- let resultado;
733
- try {
734
- resultado = await be.procedure.consistir_encuesta.coreFunction(context, param_proc, client);
735
- }
736
- catch (err) {
737
- errMessage = " consistir_vivienda. " + err;
738
- console.log(errMessage);
739
- }
740
- console.log('****** consistir_vivienda resultado:', resultado);
741
- return {
742
- ok: 'ok'
743
- };
744
- }
745
- },
746
- {
747
- action: 'dm_rescatar',
748
- parameters: [
749
- { name: 'localStorageItem', typeName: 'jsonb' },
750
- { name: 'localStorageItemKey', typeName: 'text' },
751
- ],
752
- unlogged: true,
753
- coreFunction: async function (context, params) {
754
- var { localStorageItemKey, localStorageItem } = params;
755
- try {
756
- console.log(localStorageItem);
757
- await fs_1.promises.appendFile('local-rescate.txt', JSON.stringify({ now: new Date(), user: context.username, itemKey: localStorageItemKey, itemData: localStorageItem }) + '\n\n', 'utf8');
758
- return 'ok';
759
- }
760
- catch (err) {
761
- console.log('ERROR', err);
762
- throw err;
763
- }
764
- }
765
- },
766
- {
767
- action: 'operativo_get',
768
- parameters: [],
769
- unlogged: true,
770
- coreFunction: async function (context, _parameters) {
771
- return (0, exports.getOperativoActual)(context);
772
- }
773
- },
774
- {
775
- action: 'get_random_free_case',
776
- parameters: [{ name: 'operativo', typeName: 'text' }],
777
- coreFunction: async function (context, params) {
778
- const minsToExpire = 30;
779
- const minsSinceBloqued = `date_part('min', age(current_timestamp, fecha_bloqueo))`;
780
- const enc = await context.client.query(`select enc from tem where operativo=$1 and (libre or ${minsSinceBloqued} > ${minsToExpire}) limit 1;`, [params.operativo]).fetchUniqueValue();
781
- await context.client.query(`UPDATE tem set libre = false, fecha_bloqueo=current_timestamp where operativo=$1 and enc=$2`, [params.operativo, enc.value]).execute();
782
- return enc.value;
783
- }
784
- },
785
- {
786
- action: 'accion_tareas_tem_ejecutar',
787
- parameters: [
788
- { name: 'operativo', typeName: 'text' },
789
- { name: 'tarea', typeName: 'text' },
790
- { name: 'enc', typeName: 'text' },
791
- { name: 'condicion', typeName: 'text' },
792
- { name: 'accion', typeName: 'jsonb' },
793
- ],
794
- coreFunction: async function (context, params) {
795
- var be = context.be;
796
- var accion = params.accion;
797
- const ANALIZAR_CONDICION = true;
798
- if (ANALIZAR_CONDICION) {
711
+ returning 'ok'`, [OPERATIVO, backup.forPkRaiz.vivienda, backup.respuestasRaiz, backup.respuestasRaiz]).fetchOneRowIfExists();
712
+ }).array());
713
+ }
714
+ return {
715
+ ok: 'ok'
716
+ };
717
+ }
718
+ },
719
+ {
720
+ action: 'consistir_vivienda',
721
+ parameters: [
722
+ { name: 'operativo', references: 'operativos', typeName: 'text' },
723
+ { name: 'vivienda', typeName: 'text' },
724
+ ],
725
+ coreFunction: async function (context, parameters) {
726
+ var { be, client } = context;
727
+ let param_proc = {
728
+ operativo: parameters.operativo,
729
+ id_caso: parameters.vivienda
730
+ };
731
+ let errMessage;
732
+ let resultado;
733
+ try {
734
+ resultado = await be.procedure.consistir_encuesta.coreFunction(context, param_proc, client);
735
+ }
736
+ catch (err) {
737
+ errMessage = " consistir_vivienda. " + err;
738
+ console.log(errMessage);
739
+ }
740
+ console.log('****** consistir_vivienda resultado:', resultado);
741
+ return {
742
+ ok: 'ok'
743
+ };
744
+ }
745
+ },
746
+ {
747
+ action: 'dm_rescatar',
748
+ parameters: [
749
+ { name: 'localStorageItem', typeName: 'jsonb' },
750
+ { name: 'localStorageItemKey', typeName: 'text' },
751
+ ],
752
+ unlogged: true,
753
+ coreFunction: async function (context, params) {
754
+ var { localStorageItemKey, localStorageItem } = params;
755
+ try {
756
+ console.log(localStorageItem);
757
+ await fs_1.promises.appendFile('local-rescate.txt', JSON.stringify({ now: new Date(), user: context.username, itemKey: localStorageItemKey, itemData: localStorageItem }) + '\n\n', 'utf8');
758
+ return 'ok';
759
+ }
760
+ catch (err) {
761
+ console.log('ERROR', err);
762
+ throw err;
763
+ }
764
+ }
765
+ },
766
+ {
767
+ action: 'operativo_get',
768
+ parameters: [],
769
+ unlogged: true,
770
+ coreFunction: async function (context, _parameters) {
771
+ return (0, exports.getOperativoActual)(context);
772
+ }
773
+ },
774
+ {
775
+ action: 'get_random_free_case',
776
+ parameters: [{ name: 'operativo', typeName: 'text' }],
777
+ coreFunction: async function (context, params) {
778
+ const minsToExpire = 30;
779
+ const minsSinceBloqued = `date_part('min', age(current_timestamp, fecha_bloqueo))`;
780
+ const enc = await context.client.query(`select enc from tem where operativo=$1 and (libre or ${minsSinceBloqued} > ${minsToExpire}) limit 1;`, [params.operativo]).fetchUniqueValue();
781
+ await context.client.query(`UPDATE tem set libre = false, fecha_bloqueo=current_timestamp where operativo=$1 and enc=$2`, [params.operativo, enc.value]).execute();
782
+ return enc.value;
783
+ }
784
+ },
785
+ {
786
+ action: 'accion_tareas_tem_ejecutar',
787
+ parameters: [
788
+ { name: 'operativo', typeName: 'text' },
789
+ { name: 'tarea', typeName: 'text' },
790
+ { name: 'enc', typeName: 'text' },
791
+ { name: 'condicion', typeName: 'text' },
792
+ { name: 'accion', typeName: 'jsonb' },
793
+ ],
794
+ coreFunction: async function (context, params) {
795
+ var be = context.be;
796
+ var accion = params.accion;
797
+ const ANALIZAR_CONDICION = true;
798
+ if (ANALIZAR_CONDICION) {
799
799
  var cumple = (await context.client.query(`select accion_cumple_condicion($5, $6, $7, $8, (
800
800
  select condicion
801
801
  from estados_acciones
802
802
  where operativo = $1 and estado = $2 and eaccion = $3 and estado_destino = $4
803
803
  )
804
- )`, [
805
- params.operativo,
806
- accion.estado,
807
- accion.eaccion,
808
- accion.estado_destino,
809
- params.operativo,
810
- accion.estado,
811
- params.enc,
812
- accion.eaccion,
813
- ])
814
- .fetchUniqueValue()).value;
815
- if (!cumple) {
816
- throw Error(`No se pudo ejecutar la acción, no se cumple la condición "${params.condicion}" o bien el estado está desactualizado, refresque la grilla.`);
817
- }
818
- }
804
+ )`, [
805
+ params.operativo,
806
+ accion.estado,
807
+ accion.eaccion,
808
+ accion.estado_destino,
809
+ params.operativo,
810
+ accion.estado,
811
+ params.enc,
812
+ accion.eaccion,
813
+ ])
814
+ .fetchUniqueValue()).value;
815
+ if (!cumple) {
816
+ throw Error(`No se pudo ejecutar la acción, no se cumple la condición "${params.condicion}" o bien el estado está desactualizado, refresque la grilla.`);
817
+ }
818
+ }
819
819
  var result = await context.client.query(`
820
820
  UPDATE tareas_tem
821
821
  set estado = $4
822
822
  where operativo=$1
823
823
  and enc=$2
824
824
  and tarea = $3
825
- returning *`, [
826
- params.operativo,
827
- params.enc,
828
- params.tarea,
829
- accion.estado_destino
830
- ]).fetchUniqueRow();
831
- if (accion.nombre_procedure) {
832
- if (be.procedure[accion.nombre_procedure]) {
833
- await be.procedure[accion.nombre_procedure].coreFunction(context, params);
834
- }
835
- else {
825
+ returning *`, [
826
+ params.operativo,
827
+ params.enc,
828
+ params.tarea,
829
+ accion.estado_destino
830
+ ]).fetchUniqueRow();
831
+ if (accion.nombre_procedure) {
832
+ if (be.procedure[accion.nombre_procedure]) {
833
+ await be.procedure[accion.nombre_procedure].coreFunction(context, params);
834
+ }
835
+ else {
836
836
  throw Error(`No existe el procedure "${accion.nombre_procedure}" definido en la tabla "estados_acciones" para el
837
- operativo: ${accion.operativo}, estado: ${accion.estado}, eaccion: ${accion.eaccion}.`);
838
- }
839
- }
840
- return result.row;
841
- }
842
- },
843
- {
844
- action: 'encuesta_carga_preparar',
845
- parameters: [
846
- { name: 'operativo', typeName: 'text' },
847
- { name: 'tarea', typeName: 'text' },
848
- { name: 'enc', typeName: 'text' },
849
- ],
850
- coreFunction: async function (context, params) {
837
+ operativo: ${accion.operativo}, estado: ${accion.estado}, eaccion: ${accion.eaccion}.`);
838
+ }
839
+ }
840
+ return result.row;
841
+ }
842
+ },
843
+ {
844
+ action: 'encuesta_carga_preparar',
845
+ parameters: [
846
+ { name: 'operativo', typeName: 'text' },
847
+ { name: 'tarea', typeName: 'text' },
848
+ { name: 'enc', typeName: 'text' },
849
+ ],
850
+ coreFunction: async function (context, params) {
851
851
  await context.client.query(`
852
852
  UPDATE tareas_tem
853
853
  set operacion = 'cargar'
854
854
  where operativo=$1 and tarea= $2 and enc=$3
855
- returning *`, [params.operativo, params.tarea, params.enc])
856
- .fetchUniqueRow();
857
- return 'ok';
858
- }
859
- },
860
- {
861
- action: 'encuesta_disponibilizar',
862
- parameters: [
863
- { name: 'operativo', typeName: 'text' },
864
- { name: 'tarea', typeName: 'text' },
865
- { name: 'enc', typeName: 'text' },
866
- ],
867
- coreFunction: async function (context, params) {
855
+ returning *`, [params.operativo, params.tarea, params.enc])
856
+ .fetchUniqueRow();
857
+ return 'ok';
858
+ }
859
+ },
860
+ {
861
+ action: 'encuesta_disponibilizar',
862
+ parameters: [
863
+ { name: 'operativo', typeName: 'text' },
864
+ { name: 'tarea', typeName: 'text' },
865
+ { name: 'enc', typeName: 'text' },
866
+ ],
867
+ coreFunction: async function (context, params) {
868
868
  await context.client.query(`
869
869
  UPDATE tareas_tem
870
870
  set asignado = null
871
871
  where operativo=$1 and tarea= $2 and enc=$3
872
- returning *`, [params.operativo, params.tarea, params.enc])
873
- .fetchUniqueRow();
874
- return 'ok';
875
- }
876
- },
877
- {
878
- action: 'encuesta_no_cargar',
879
- parameters: [
880
- { name: 'operativo', typeName: 'text' },
881
- { name: 'tarea', typeName: 'text' },
882
- { name: 'enc', typeName: 'text' },
883
- ],
884
- coreFunction: async function (context, params) {
872
+ returning *`, [params.operativo, params.tarea, params.enc])
873
+ .fetchUniqueRow();
874
+ return 'ok';
875
+ }
876
+ },
877
+ {
878
+ action: 'encuesta_no_cargar',
879
+ parameters: [
880
+ { name: 'operativo', typeName: 'text' },
881
+ { name: 'tarea', typeName: 'text' },
882
+ { name: 'enc', typeName: 'text' },
883
+ ],
884
+ coreFunction: async function (context, params) {
885
885
  await context.client.query(`
886
886
  UPDATE tareas_tem
887
887
  set operacion = null
888
888
  where operativo=$1 and tarea= $2 and enc=$3
889
- returning *`, [params.operativo, params.tarea, params.enc])
890
- .fetchUniqueRow();
891
- return 'ok';
892
- }
893
- },
894
- {
895
- action: 'encuesta_descarga_preparar',
896
- parameters: [
897
- { name: 'operativo', typeName: 'text' },
898
- { name: 'tarea', typeName: 'text' },
899
- { name: 'enc', typeName: 'text' },
900
- ],
901
- coreFunction: async function (context, params) {
889
+ returning *`, [params.operativo, params.tarea, params.enc])
890
+ .fetchUniqueRow();
891
+ return 'ok';
892
+ }
893
+ },
894
+ {
895
+ action: 'encuesta_descarga_preparar',
896
+ parameters: [
897
+ { name: 'operativo', typeName: 'text' },
898
+ { name: 'tarea', typeName: 'text' },
899
+ { name: 'enc', typeName: 'text' },
900
+ ],
901
+ coreFunction: async function (context, params) {
902
902
  await context.client.query(`
903
903
  UPDATE tareas_tem
904
904
  set operacion = 'descargar'
905
905
  where operativo=$1 and tarea= $2 and enc=$3
906
- returning *`, [params.operativo, params.tarea, params.enc])
907
- .fetchUniqueRow();
908
- return 'ok';
909
- }
910
- },
911
- {
912
- action: 'encuesta_no_descargar',
913
- parameters: [
914
- { name: 'operativo', typeName: 'text' },
915
- { name: 'tarea', typeName: 'text' },
916
- { name: 'enc', typeName: 'text' },
917
- ],
918
- coreFunction: async function (context, params) {
906
+ returning *`, [params.operativo, params.tarea, params.enc])
907
+ .fetchUniqueRow();
908
+ return 'ok';
909
+ }
910
+ },
911
+ {
912
+ action: 'encuesta_no_descargar',
913
+ parameters: [
914
+ { name: 'operativo', typeName: 'text' },
915
+ { name: 'tarea', typeName: 'text' },
916
+ { name: 'enc', typeName: 'text' },
917
+ ],
918
+ coreFunction: async function (context, params) {
919
919
  await context.client.query(`
920
920
  UPDATE tareas_tem
921
921
  set operacion = 'cargar'
922
922
  where operativo=$1 and tarea= $2 and enc=$3
923
- returning *`, [params.operativo, params.tarea, params.enc])
924
- .fetchUniqueRow();
925
- return 'ok';
926
- }
927
- },
928
- {
929
- action: 'encuesta_analizar',
930
- parameters: [
931
- { name: 'operativo', typeName: 'text' },
932
- { name: 'tarea', typeName: 'text' },
933
- { name: 'enc', typeName: 'text' },
934
- ],
935
- coreFunction: async function (context, params) {
936
- var be = context.be;
937
- await be.procedure.consistir_vivienda.coreFunction(context, { operativo: params.operativo, vivienda: params.enc });
938
- return 'ok';
939
- }
940
- },
941
- {
942
- action: 'encuesta_verificar',
943
- parameters: [
944
- { name: 'operativo', typeName: 'text' },
945
- { name: 'tarea', typeName: 'text' },
946
- { name: 'enc', typeName: 'text' },
947
- ],
948
- coreFunction: async function (context, params) {
923
+ returning *`, [params.operativo, params.tarea, params.enc])
924
+ .fetchUniqueRow();
925
+ return 'ok';
926
+ }
927
+ },
928
+ {
929
+ action: 'encuesta_analizar',
930
+ parameters: [
931
+ { name: 'operativo', typeName: 'text' },
932
+ { name: 'tarea', typeName: 'text' },
933
+ { name: 'enc', typeName: 'text' },
934
+ ],
935
+ coreFunction: async function (context, params) {
936
+ var be = context.be;
937
+ await be.procedure.consistir_encuesta.coreFunction(context, { operativo: params.operativo, id_caso: params.enc });
938
+ return 'ok';
939
+ }
940
+ },
941
+ {
942
+ action: 'encuesta_verificar',
943
+ parameters: [
944
+ { name: 'operativo', typeName: 'text' },
945
+ { name: 'tarea', typeName: 'text' },
946
+ { name: 'enc', typeName: 'text' },
947
+ ],
948
+ coreFunction: async function (context, params) {
949
949
  await context.client.query(`
950
950
  UPDATE tareas_tem
951
951
  set verificado = '1'
952
952
  where operativo=$1 and tarea= $2 and enc=$3
953
- returning *`, [params.operativo, params.tarea, params.enc])
954
- .fetchUniqueRow();
955
- return 'ok';
956
- }
957
- },
958
- {
959
- action: 'encuesta_no_verificar',
960
- parameters: [
961
- { name: 'operativo', typeName: 'text' },
962
- { name: 'tarea', typeName: 'text' },
963
- { name: 'enc', typeName: 'text' },
964
- ],
965
- coreFunction: async function (context, params) {
953
+ returning *`, [params.operativo, params.tarea, params.enc])
954
+ .fetchUniqueRow();
955
+ return 'ok';
956
+ }
957
+ },
958
+ {
959
+ action: 'encuesta_no_verificar',
960
+ parameters: [
961
+ { name: 'operativo', typeName: 'text' },
962
+ { name: 'tarea', typeName: 'text' },
963
+ { name: 'enc', typeName: 'text' },
964
+ ],
965
+ coreFunction: async function (context, params) {
966
966
  await context.client.query(`
967
967
  UPDATE tareas_tem
968
968
  set verificado = null
969
969
  where operativo=$1 and tarea= $2 and enc=$3
970
- returning *`, [params.operativo, params.tarea, params.enc])
971
- .fetchUniqueRow();
972
- return 'ok';
973
- }
974
- },
975
- {
976
- action: 'encuesta_dpt',
977
- parameters: [
978
- { name: 'operativo', typeName: 'text' },
979
- { name: 'tarea', typeName: 'text' },
980
- { name: 'enc', typeName: 'text' },
981
- ],
982
- coreFunction: async function (context, params) {
983
- //TODO acá hay que preparar la siguiente tarea
984
- return 'ok';
985
- }
986
- },
987
- {
988
- action: 'encuesta_habilitar_deshabilitar',
989
- parameters: [
990
- { name: 'operativo', typeName: 'text' },
991
- { name: 'enc', typeName: 'text' },
992
- ],
993
- coreFunction: async function (context, params) {
970
+ returning *`, [params.operativo, params.tarea, params.enc])
971
+ .fetchUniqueRow();
972
+ return 'ok';
973
+ }
974
+ },
975
+ {
976
+ action: 'encuesta_dpt',
977
+ parameters: [
978
+ { name: 'operativo', typeName: 'text' },
979
+ { name: 'tarea', typeName: 'text' },
980
+ { name: 'enc', typeName: 'text' },
981
+ ],
982
+ coreFunction: async function (context, params) {
983
+ //TODO acá hay que preparar la siguiente tarea
984
+ return 'ok';
985
+ }
986
+ },
987
+ {
988
+ action: 'encuesta_habilitar_deshabilitar',
989
+ parameters: [
990
+ { name: 'operativo', typeName: 'text' },
991
+ { name: 'enc', typeName: 'text' },
992
+ ],
993
+ coreFunction: async function (context, params) {
994
994
  await context.client.query(`
995
995
  UPDATE tem
996
996
  set habilitada = not habilitada
997
997
  where operativo=$1 and enc=$2
998
- returning *`, [params.operativo, params.enc])
999
- .fetchUniqueRow();
1000
- return 'ok';
1001
- }
1002
- },
1003
- ];
1004
- });
1005
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedures-dmencu.js","sourceRoot":"","sources":["../../../src/server/procedures-dmencu.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport { ProcedureDef, TableDefinition, Client } from \"./types-dmencu\";\r\nimport { ProcedureContext, CoreFunctionParameters, ForeignKey } from \"meta-enc\";\r\nimport * as likeAr from \"like-ar\";\r\nexport * from \"./types-dmencu\";\r\nimport { IdUnidadAnalisis, UnidadAnalisis, EstadoAccion } from \"../unlogged/tipos\";\r\n\r\nimport {json, jsono} from \"pg-promise-strict\";\r\n\r\nimport {changing, date } from 'best-globals';\r\nimport {promises as  fs} from \"fs\";\r\n\r\nimport * as ExpresionParser from 'expre-parser';\r\nimport { tareas } from \"./table-tareas\";\r\nimport { prependListener } from \"process\";\r\n\r\nvar path = require('path');\r\nvar sqlTools = require('sql-tools');\r\n\r\nvar discrepances = require('discrepances');\r\n\r\nconst formPrincipal = 'F:F1';\r\nconst MAIN_TABLENAME ='viviendas';\r\n\r\nexport const getOperativoActual = async (context:ProcedureContext)=>{\r\n    var be = context.be;\r\n    var result = await be.procedure.table_data.coreFunction(context,{table: `parametros`, fixedFields:[]});\r\n    if(result[0]?.operativo){\r\n        return result[0].operativo\r\n    }else{\r\n        throw Error ('no se configuró un operativo en la tabla parámetros');\r\n    }\r\n}\r\n\r\n\r\n/*definición de estructura completa, cuando exista ing-enc hay que ponerlo ahí*/ \r\ntype EstructuraTabla={tableName:string, pkFields:{fieldName:string}[], childTables:EstructuraTabla[]};\r\nfunction createStructure(context:ProcedureContext, tableName:string){\r\n    var be = context.be;\r\n    var mainTableDef:TableDefinition = be.tableStructures[tableName](context);\r\n    var getPkFromTableDef = function getPkFromTableDef(tableDef:TableDefinition){\r\n        return tableDef.primaryKey.map(function(pk){\r\n            return {fieldName:pk};\r\n        })\r\n    };\r\n    var getFkFromTableDef = function getFkFromTableDef(tableDef:TableDefinition, parentTableName: string){\r\n        // return tableDef.foreignKeys? tableDef.foreignKeys.map(fk=>fk.fields): [];\r\n        let parentFk = (<ForeignKey[]> tableDef.foreignKeys).find(fk=>fk.references == parentTableName);\r\n        return parentFk? parentFk.fields: [];\r\n    }\r\n    var struct:EstructuraTabla={\r\n        tableName:mainTableDef.name,\r\n        pkFields:getPkFromTableDef(mainTableDef),\r\n        childTables:[]\r\n    };\r\n    if(mainTableDef.detailTables && mainTableDef.detailTables.length){\r\n        mainTableDef.detailTables.forEach(function(detailTable){\r\n            struct.childTables.push(\r\n                changing(\r\n                    createStructure(context, detailTable.table),\r\n                    {fkFields: getFkFromTableDef(be.tableStructures[detailTable.table](context), tableName)}\r\n                )\r\n            );\r\n        })\r\n    }\r\n    return struct;\r\n}\r\n/* fin definicion estructura completa */\r\n\r\ntype AnyObject = {[k:string]:any}\r\n\r\nvar getParametersAndSettersForUpdateTem = async (context, operativo, idEnc, respuestasUAPrincipal, tarea)=>{\r\n    var registraEstadoEnTem = (await context.client.query(\r\n        `select registra_estado_en_tem\r\n            from tareas\r\n            where operativo=$1 and tarea = $2`\r\n        ,\r\n        [operativo, tarea]\r\n    ).fetchUniqueValue()).value;\r\n    var params = [operativo, idEnc, respuestasUAPrincipal]\r\n    var setters = `json_encuesta = $3`;\r\n    //TODO ARREGLAR ESTE HORROR, GENERALIZAR\r\n    if(tarea=='supe'){\r\n        setters+= `, resumen_estado_sup=$4, norea_sup=$5, rea_sup=$6`\r\n        params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);\r\n    }else{\r\n        setters+= `, resumen_estado=$4, norea=$5, rea=$6`\r\n        params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);\r\n    }\r\n    return {setters, params}\r\n}\r\n\r\nvar getHdrQuery =  function getHdrQuery(quotedCondViv:string){\r\n    return `\r\n    with viviendas as \r\n        (select t.enc, t.json_encuesta as respuestas, t.resumen_estado as \"resumenEstado\", \r\n            jsonb_build_object(\r\n                'dominio'       , dominio       ,\r\n                'nomcalle'      , nomcalle      ,\r\n                'sector'        , sector        ,\r\n                'edificio'      , edificio      ,\r\n                'entrada'       , entrada       ,\r\n                'nrocatastral'  , nrocatastral  ,\r\n                'piso'          , piso          ,\r\n                'departamento'  , departamento  ,\r\n                'habitacion'    , habitacion    ,\r\n                'casa'          , casa          ,\r\n                'prioridad'     , reserva+1     ,\r\n                'observaciones' , tt.carga_observaciones ,\r\n                'cita'          , cita ,\r\n                'carga'         , t.area         \r\n            ) as tem, t.area,\r\n            --TODO: GENERALIZAR\r\n            jsonb_build_object(\r\n                'tarea', tt.tarea,\r\n                'fecha_asignacion', fecha_asignacion,\r\n                'asignado', asignado,\r\n                'main_form', main_form\r\n            ) as tarea,\r\n            min(fecha_asignacion) as fecha_asignacion\r\n            from tem t left join tareas_tem tt on (t.operativo = tt.operativo and t.enc = tt.enc and t.tarea_actual = tt.tarea)\r\n                       left join tareas ta on t.tarea_actual = ta.tarea\r\n            where t.habilitada and ${quotedCondViv}\r\n            group by t.enc, t.json_encuesta, t.resumen_estado, dominio, nomcalle,sector,edificio, entrada, nrocatastral, piso,departamento,habitacion,casa,reserva,tt.carga_observaciones, cita, t.area, tt.tarea, fecha_asignacion, asignado, main_form\r\n        )\r\n        select jsonb_build_object(\r\n                'viviendas', ${jsono(\r\n                    `select enc, respuestas, jsonb_build_object('resumenEstado',\"resumenEstado\") as otras from viviendas`,\r\n                    'enc',\r\n                    `otras || coalesce(respuestas,'{}'::jsonb)`\r\n                )}\r\n            ) as respuestas,\r\n            ${json(`\r\n                select area as carga, observaciones_hdr as observaciones, min(fecha_asignacion) as fecha\r\n                    from viviendas inner join areas using (area) \r\n                    group by area, observaciones_hdr`, \r\n                'fecha')} as cargas,\r\n            ${jsono(\r\n                `select enc, jsonb_build_object('tem', tem, 'tarea', tarea) as otras from viviendas`,\r\n                 'enc',\r\n                 `otras ||'{}'::jsonb`\r\n                )}\r\n            as \"informacionHdr\"\r\n`\r\n}\r\n\r\nexport var setHdrQuery = (myFun:(quotedCondViv:string)=>string)=> getHdrQuery=myFun\r\n\r\nconst getUAPrincipal = async (client:Client, operativo:string)=>\r\n    (await client.query(\r\n        `select unidad_analisis\r\n            from unidad_analisis\r\n            where operativo= $1 and principal\r\n        `\r\n        ,\r\n        [operativo]\r\n    ).fetchUniqueValue()).value\r\n\r\nvar funcionesConocidas:{[k in string]:boolean} = {}\r\n\r\nvar compiler = new ExpresionParser.Compiler({\r\n    language:'js',\r\n    varWrapper:(var_name:string)=>`helpers.null2zero(valores.${var_name})`,\r\n    funWrapper:(functionName:string)=>{\r\n        if(!funcionesConocidas[functionName]){\r\n            console.log(functionName)\r\n            funcionesConocidas[functionName] = true;\r\n        }\r\n        return `helpers.funs.${functionName}`\r\n    }\r\n})\r\n\r\ntype CasilleroDeAca={\r\n    childs: CasilleroDeAca[],\r\n    data:{\r\n        expresion_habilitar: string\r\n        expresion_habilitar_js: string\r\n        especial: any\r\n        expresion_autoingresar_js: string\r\n    }\r\n}\r\n\r\nfunction compilarExpresion(expresion:string){\r\n    return compiler.toCode(ExpresionParser.parse(\r\n        expresion\r\n            .replace(/\\bis distinct from\\b/gi,' <> ')\r\n            .replace(/!!/gi,' ')\r\n    )).replace(/helpers\\.funs\\.blanco\\(helpers.null2zero\\(/g,'helpers.funs.blanco((')\r\n    .replace(/helpers\\.funs\\.informado\\(helpers.null2zero\\(/g,'helpers.funs.informado((');\r\n}\r\n\r\nfunction compilarExpresiones(casillero:CasilleroDeAca){\r\n    if(!casillero){ return }\r\n    if(casillero.data.expresion_habilitar){\r\n        casillero.data.expresion_habilitar_js = compilarExpresion(casillero.data.expresion_habilitar);\r\n    }\r\n    if(casillero.data.especial?.autoing){\r\n        var partes = casillero.data.especial?.autoing.split('=>');\r\n        if(partes.length>1){\r\n            var precondicion = partes[0];\r\n            var valor = partes.slice(1).join('=>');\r\n            casillero.data.expresion_autoingresar_js = `(${compilarExpresion(precondicion)})?(${compilarExpresion(valor)}):null`;\r\n        }else{\r\n            casillero.data.expresion_autoingresar_js = compilarExpresion(partes[0]);\r\n        }\r\n    }\r\n    for(var casilleroInterno of casillero.childs) compilarExpresiones(casilleroInterno);\r\n}\r\n\r\nexport const ProceduresDmEncu : ProcedureDef[] = [\r\n    {\r\n        action:'operativo_estructura_completa',\r\n        parameters:[\r\n            {name:'operativo'            ,typeName:'text', references:'operativos'},\r\n        ],\r\n        resultOk:'desplegarFormulario',\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be = context.be;\r\n            var result = await context.client.query(\r\n                `select casilleros_jerarquizados($1) as formularios, \r\n                    ${jsono(`select unidad_analisis, padre, pk_agregada, '{}'::jsonb as hijas from unidad_analisis`, 'unidad_analisis')} as unidades_analisis\r\n                `,\r\n                [parameters.operativo]\r\n            ).fetchUniqueRow();\r\n            likeAr(result.row.formularios).forEach(f=>compilarExpresiones(f));\r\n            // Hermanos son los formularios que están implantados en otro formulario de la misma UA. Por ejemplo el A1 en el S1\r\n            var resultHermanos = await context.client.query(`\r\nselect o.id_casillero as id_formulario, o.unidad_analisis, 'BF_'||o.casillero boton, bf.casillero, bf.padre, fp.casillero, fp.unidad_analisis\r\n  from casilleros o left join casilleros bf\r\n    on bf.tipoc='BF'\r\n\tand bf.casillero = 'BF_'||o.casillero\r\n\tand bf.operativo = o.operativo\r\n\tleft join casilleros fp\r\n\t  on fp.id_casillero = bf.padre\r\n\t  and fp.operativo = bf.operativo\r\n  where o.tipoc = 'F'\r\n    and o.unidad_analisis = fp.unidad_analisis\r\n\tand o.operativo = $1`,\r\n                [parameters.operativo]\r\n            ).fetchAll();\r\n            resultHermanos.rows.forEach(row=>{\r\n                result.row.formularios[row.id_formulario].data.hermano = true;\r\n            })\r\n            function completarUA(ua:UnidadAnalisis, idUa:IdUnidadAnalisis, uAs:{[k in IdUnidadAnalisis]: UnidadAnalisis}){\r\n                if(ua.padre){\r\n                    uAs[ua.padre].hijas[idUa] = ua;\r\n                }else{\r\n                    ua.principal=true;\r\n                }\r\n            }\r\n            likeAr(result.row.unidades_analisis).forEach((ua, idUa)=>\r\n                completarUA(ua, idUa as IdUnidadAnalisis, result.row.unidades_analisis)\r\n            )\r\n            var configSorteo = (await context.client.query(`\r\n                select config_sorteo \r\n                    from operativos \r\n                    where operativo = $1\r\n            `,[parameters.operativo]).fetchUniqueValue()).value;\r\n            let compilarExpresionesDominios = (expresionesDominio:any)=> \r\n                likeAr(expresionesDominio)\r\n                    .map((expr,dominio)=>({dominio, expr:compilarExpresion(expr.expr)}))\r\n                    .plain();\r\n            if(configSorteo){\r\n                likeAr(configSorteo).forEach((configSorteoFormulario)=>{\r\n                    configSorteoFormulario.expr_incompletitud_js=compilarExpresionesDominios(configSorteoFormulario.expr_incompletitud)\r\n                    configSorteoFormulario.filtro_js=compilarExpresionesDominios(configSorteoFormulario.filtro)\r\n                })\r\n            }\r\n            return {timestamp: be.timestampEstructura, ...result.row, operativo:parameters.operativo, configSorteo,noReas:be.caches.tableContent.no_rea, noReasSup:be.caches.tableContent.no_rea_sup};\r\n        }\r\n    },\r\n    {\r\n        action:'generar_formularios',\r\n        parameters:[\r\n            {name:'annio', typeName:'integer', references:'annio'},\r\n            {name:'mes'  , typeName:'integer', references:'mes'  },\r\n            {name:'lote' , typeName:'integer', references:'lotes'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be=context.be;\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            let resultUA = await context.client.query(\r\n                `select *\r\n                   from unidad_analisis\r\n                   where principal = true and operativo = $1\r\n                `,\r\n                [OPERATIVO]\r\n            ).fetchOneRowIfExists();\r\n            if (resultUA.rowCount === 0){\r\n                throw new Error('No se configuró una unidad de analisis como principal');\r\n            }\r\n            let row = resultUA.row;\r\n            let resultPreguntas = await be.procedure.preguntas_ua_traer.coreFunction(context, row)\r\n            var contenedorVacio:{[key:string]:any} = {};\r\n            resultPreguntas.forEach(function(defPregunta){\r\n                contenedorVacio[defPregunta.var_name] = defPregunta.unidad_analisis?[]:null;\r\n            });\r\n            contenedorVacio.annio= parameters.annio;\r\n            contenedorVacio.mes  = parameters.mes  ;\r\n            contenedorVacio.lote = parameters.lote ;\r\n            \r\n            var result = await context.client.query(\r\n                `select debe_haber.id_caso, s as id\r\n                    from (select lote, armar_id(annio, mes, lote, s) as id_caso, s\r\n                        from (select annio,mes,lote, cant_cues from lotes where (annio,mes,lote)=($2,$3,$4)) r, lateral generate_series(1,cant_cues) s\r\n                    ) debe_haber left join defgen hay on hay.id_caso = debe_haber.id_caso and hay.operativo=$1\r\n                    where hay.id_caso is null`,\r\n                [ OPERATIVO, parameters.annio, parameters.mes, parameters.lote]\r\n            ).fetchAll();\r\n            var params = {operativo: OPERATIVO};\r\n            for(var i=0; i < result.rowCount; i++){\r\n                await be.procedure.caso_guardar.coreFunction(\r\n                    context, \r\n                    changing(params,{id_caso:result.rows[i].id_caso, datos_caso:changing(contenedorVacio,{id:result.rows[i].id})})\r\n                )\r\n            }\r\n            return {agregadas:result.rowCount}\r\n        }\r\n    },\r\n    {\r\n        action:'upload_file',\r\n        progress: true,\r\n        parameters:[\r\n            {name: 'id_adjunto', typeName: 'integer'},\r\n            {name: 'nombre', typeName: 'text'},\r\n        ],\r\n        files:{count:1},\r\n        coreFunction:function(context:ProcedureContext, parameters:CoreFunctionParameters, files){\r\n            let be=context.be;\r\n            let client=context.client;\r\n            context.informProgress({message:be.messages.fileUploaded});\r\n            let file = files[0]\r\n            let ext = path.extname(file.path).substr(1);\r\n            let originalFilename = file.originalFilename.slice(0,-(ext.length+1));\r\n            let filename= parameters.nombre || originalFilename;\r\n            let newPath = 'local-attachments/file-';\r\n            var createResponse = function createResponse(adjuntoRow){\r\n                let resultado = {\r\n                    message: 'La subida se realizó correctamente (update)',\r\n                    nombre: adjuntoRow.nombre,\r\n                    nombre_original: adjuntoRow.nombre_original,\r\n                    ext: adjuntoRow.ext,\r\n                    fecha: adjuntoRow.fecha,\r\n                    hora: adjuntoRow.hora,\r\n                    id_adjunto: adjuntoRow.id_adjunto\r\n                }\r\n                return resultado\r\n            }\r\n            var moveFile = function moveFile(file, id_adjunto, extension){\r\n                fs.move(file.path, newPath + id_adjunto + '.' + extension, { overwrite: true });\r\n            }\r\n            return Promise.resolve().then(function(){\r\n                if(parameters.id_adjunto){\r\n                    return context.client.query(`update adjuntos set nombre= $1,nombre_original = $2, ext = $3, ruta = concat('local-attachments/file-',$4::text,'.',$3::text), fecha = now(), hora = date_trunc('seconds',current_timestamp-current_date)\r\n                        where id_adjunto = $4 returning *`,\r\n                        [filename, originalFilename, ext, parameters.id_adjunto]\r\n                    ).fetchUniqueRow().then(function(result){\r\n                        return createResponse(result.row)\r\n                    }).then(function(resultado){\r\n                        moveFile(file,resultado.id_adjunto,resultado.ext);\r\n                        return resultado\r\n                    });\r\n                }else{\r\n                    return context.client.query(`insert into adjuntos (nombre, nombre_original, ext, fecha, hora) values ($1,$2,$3,now(), date_trunc('seconds',current_timestamp-current_date)) returning *`,\r\n                        [filename, originalFilename, ext]\r\n                    ).fetchUniqueRow().then(function(result){\r\n                        return context.client.query(`update adjuntos set ruta = concat('local-attachments/file-',id_adjunto::text,'.',ext)\r\n                            where id_adjunto = $1 returning *`,\r\n                            [result.row.id_adjunto]\r\n                        ).fetchUniqueRow().then(function(result){\r\n                            return createResponse(result.row)\r\n                        }).then(function(resultado){\r\n                            moveFile(file,resultado.id_adjunto,resultado.ext);\r\n                            return resultado\r\n                        });\r\n                    });\r\n                }\r\n            }).catch(function(err){\r\n                throw err;\r\n            });\r\n        }\r\n    },\r\n    {\r\n        action:'caso_guardar',\r\n        parameters:[\r\n            {name:'operativo'   , typeName:'text', references:'operativos'},\r\n            {name:'id_caso'     , typeName:'text'      },\r\n            {name:'datos_caso'  , typeName:'jsonb'     },\r\n        ],\r\n        definedIn: 'dmencu',\r\n        //@ts-ignore especifico el tipo de los parámetros\r\n        coreFunction:async function(context:ProcedureContext, parameters:{\r\n            operativo:string, \r\n            id_caso:string,\r\n            datos_caso:AnyObject\r\n        },newClient:Client){\r\n            var client=newClient || context.client;\r\n            var datos_json=parameters.datos_caso;\r\n            var be = context.be;\r\n            var tableStructures_app:TableDefinitions = be.tableStructures;\r\n        \r\n            var struct_dmencu = createStructure(context, MAIN_TABLENAME);\r\n            datos_json['operativo'] = parameters.operativo;\r\n            //TODO : vivienda ó enc???\r\n            datos_json['vivienda'] = parameters.id_caso;\r\n            function completar_ult_pk_en_arr( ult_pk, ua_arr){\r\n                var con_pk_completa=ua_arr; \r\n                if (ua_arr && ua_arr.length>=1){\r\n                    con_pk_completa= con_pk_completa.map((una_ua,i)=>{\r\n                        una_ua[ult_pk]=i+1   \r\n                        return una_ua;\r\n                    })\r\n                };\r\n                return con_pk_completa\r\n            }\r\n            for( var key1 in datos_json ){\r\n                var dato_key1 = datos_json[key1];\r\n                if ( dato_key1 instanceof Array && dato_key1.length >= 1 ) {\r\n                    var pk1 = tableStructures_app[key1](context).primaryKey;\r\n                    var ult_pk1 = pk1[pk1.length-1];\r\n                    datos_json[key1] = completar_ult_pk_en_arr( ult_pk1, datos_json[key1]) \r\n                    datos_json[key1].forEach((un_key1, i1)=>{\r\n                        for ( var key2 in un_key1 ){\r\n                            if ( un_key1[key2] instanceof Array && un_key1[key2].length >= 1 ){\r\n                                var pk2 = tableStructures_app[key2](context).primaryKey;\r\n                                var ult_pk2 = pk2[pk2.length-1];            \r\n                                datos_json[key1][i1][key2] = completar_ult_pk_en_arr( ult_pk2, datos_json[key1][i1][key2])\r\n                                datos_json[key1][i1][key2].forEach(un_key2=>{\r\n                                    Object.keys(un_key2).filter( p2=>p2.startsWith('$')).forEach(pp2=>\r\n                                        delete un_key2[pp2]\r\n                                    )                                        \r\n                                })\r\n                            }\r\n                            if (key2.startsWith('$')||key2.startsWith('_')){\r\n                                delete datos_json[key1][i1][key2];\r\n                            }\r\n                        }\r\n                    });\r\n                }\r\n                if (key1.startsWith('$')){\r\n                    delete datos_json[key1];\r\n                };\r\n            }\r\n            \r\n            delete datos_json.codRea;\r\n            delete datos_json.codNoRea;\r\n            delete datos_json.resumenEstado;\r\n            delete datos_json.codReaSup;\r\n            delete datos_json.codNoReaSup;\r\n            delete datos_json.resumenEstadoSup;\r\n\r\n            if( Object.keys(datos_json).length >2){\r\n                var queries = sqlTools.structuredData.sqlWrite(datos_json, struct_dmencu);\r\n                return await queries.reduce(function(promise, query){\r\n                    return promise.then(function() {\r\n                        return client.query(query).execute().then(function(result){\r\n                            return 'ok';\r\n                        });\r\n                    });\r\n                },Promise.resolve()).then(function(){\r\n                    return \"ok\";\r\n                }).catch(function(err:Error){\r\n                    console.log(\"caso_guardar ENTRA EN EL CATCH: \",err)\r\n                    throw err\r\n                })\r\n            }else{\r\n                return 'vacio';\r\n            }    \r\n        }\r\n    },\r\n    {\r\n        action: 'caso_traer',\r\n        parameters: [\r\n            //{name:'formulario'    ,                          typeName:'text'},\r\n            {name:'operativo'     ,references:'operativos',  typeName:'text'},\r\n            {name:'id_caso'       ,typeName:'text'},\r\n        ],\r\n        resultOk: 'goToEnc',\r\n        definedIn: 'dmencu',\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var client=context.client;\r\n             var struct_dmencu = createStructure(context, MAIN_TABLENAME);\r\n            var sql = sqlTools.structuredData.sqlRead({operativo: parameters.operativo, vivienda:parameters.id_caso}, struct_dmencu);\r\n            var result = await client.query(sql).fetchUniqueValue();\r\n            var response = {\r\n                operativo: parameters.operativo,\r\n                vivienda: parameters.id_caso,\r\n                datos_caso: result.value,\r\n                //formulario: formPrincipal,\r\n            };\r\n            return response;\r\n        }\r\n    },\r\n    {\r\n        action: 'caso_traer_o_crear',\r\n        parameters: [\r\n            {name:'operativo'     ,references:'operativos',  typeName:'text'},\r\n            {name:'id_caso'       ,typeName:'text'},\r\n        ],\r\n        resultOk: 'goToEnc',\r\n        // bitacora:{always:true},\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be = context.be;\r\n            try{\r\n                var result = await be.procedure['caso_traer'].coreFunction(context, parameters);\r\n                return result\r\n            }catch(err){\r\n                var json = await be.procedure['caso_preparar'].coreFunction(context, parameters);\r\n                await be.procedure['caso_guardar'].coreFunction(context, changing(parameters, {datos_caso:json}));\r\n                return await be.procedure['caso_traer'].coreFunction(context, parameters);\r\n            }\r\n        }\r\n    },\r\n    {\r\n        action:'pasar_json2ua',\r\n        parameters:[\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, _parameters:CoreFunctionParameters){\r\n            /* GENERALIZAR: */\r\n            var be=context.be;\r\n            /* FIN-GENERALIZAR: */\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            let resultMain = await context.client.query(`SELECT * FROM ${MAIN_TABLENAME} LIMIT 1`).fetchAll();\r\n            if(resultMain.rowCount>0){\r\n                console.log('HAY DATOS',resultMain.rows)\r\n                throw new Error('HAY DATOS. NO SE PUEDE INICIAR EL PASAJE');\r\n            }\r\n            let resultJson = await context.client.query(\r\n                `SELECT operativo, enc id_caso, json_encuesta datos_caso from tem \r\n                    WHERE operativo=$1 and resumen_estado is distinct from 'vacio' and json_encuesta is not null \r\n                    order by enc `,\r\n                [OPERATIVO]\r\n            ).fetchAll();\r\n            var procedureGuardar = be.procedure.caso_guardar;\r\n            if(procedureGuardar.definedIn!='dmencu'){\r\n                throw new Error('hay que sobreescribir caso_guardar');\r\n            }\r\n            return Promise.all(resultJson.rows.map(async function(row){\r\n                let resultado = `id caso ${row.id_caso}: `;\r\n                try{\r\n                    await be.inTransaction(null, async function(client){\r\n                        resultado+= await procedureGuardar.coreFunction(context, row, client);    \r\n                    })\r\n                }catch(err){\r\n                    let errMessage = resultado + \"json2ua error. \"+ err ;\r\n                    resultado = errMessage\r\n                    console.log(errMessage)\r\n                }     \r\n                if(resultado.includes('ok')){ \r\n                    var {datos_caso, vivienda, operativo} = await be.procedure.caso_traer.coreFunction(context, {operativo:row.operativo, id_caso:row.id_caso})\r\n                    var verQueGrabo = {datos_caso, vivienda, operativo}\r\n                    try{\r\n                        discrepances.showAndThrow(verQueGrabo,row)\r\n                    }catch(err){\r\n                        console.log(verQueGrabo,row)\r\n                    }\r\n                }\r\n                return resultado;\r\n            })).catch(function(err){\r\n                throw err;\r\n            }).then(function(result){\r\n                return result;\r\n            })\r\n        }\r\n    },\r\n    {\r\n        action:'dm_forpkraiz_cargar',\r\n        parameters:[\r\n            {name:'operativo'         , typeName:'text'},\r\n            {name:'vivienda'          , typeName:'text'},\r\n            {name:'tarea'             , typeName:'text', references:\"tareas\"},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var be=context.be;\r\n            var {operativo,vivienda, tarea} = parameters;\r\n            var main_form = (await context.client.query(\r\n                `select main_form\r\n                    from tareas\r\n                    where operativo= $1 and tarea=$2`\r\n                ,\r\n                [operativo, tarea]\r\n            ).fetchUniqueValue()).value;\r\n            var condviv= ` t.operativo= $1 and t.enc =$2`;\r\n            var soloLectura = !!(await context.client.query(\r\n                `select *\r\n                    from tareas_tem\r\n                    where operativo= $1 and enc = $2 and cargado_dm is not null`\r\n                ,\r\n                [operativo, vivienda]\r\n            ).fetchOneRowIfExists()).rowCount;\r\n            var {row} = await context.client.query(getHdrQuery(condviv),[operativo,vivienda]).fetchUniqueRow();\r\n            row.informacionHdr[vivienda].tarea={\r\n                tarea,\r\n                main_form\r\n            } ;\r\n            return {\r\n                ...row,\r\n                operativo,\r\n                soloLectura,\r\n                idPer:context.user.idper,\r\n                cargas:likeAr.createIndex(row.cargas.map(carga=>({...carga, fecha:carga.fecha?date.iso(carga.fecha).toDmy():null})), 'carga'),\r\n                timestampEstructura:be.timestampEstructura\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action:'dm_forpkraiz_descargar',\r\n        parameters:[\r\n            {name:'operativo'         , typeName:'text'},\r\n            {name:'persistentes'      , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var be=context.be;\r\n            var {operativo, persistentes} = parameters;\r\n            const UA_PRINCIPAL = await getUAPrincipal(context.client, operativo);\r\n            await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal,idEnc)=>{\r\n                if(respuestasUAPrincipal.s1a1_obs == '!prueba de error al grabar!'){\r\n                    throw new Error('DIO PRUEBA DE ERROR AL GRABAR');\r\n                }\r\n                var {params, setters} = await getParametersAndSettersForUpdateTem(context, operativo, idEnc, respuestasUAPrincipal, persistentes.informacionHdr[idEnc].tarea.tarea);\r\n                await context.client.query(\r\n                    `update tem\r\n                        set ${setters}\r\n                        where operativo= $1 and enc = $2\r\n                        returning 'ok'`\r\n                    ,\r\n                    params\r\n                ).fetchUniqueRow();\r\n                //guardar paralelamente en tablas ua\r\n                var procedureGuardar = be.procedure.caso_guardar;\r\n                let resultado = `id enc ${idEnc}: `;\r\n                let param_guardar={operativo: operativo,id_caso:idEnc, datos_caso:respuestasUAPrincipal}\r\n                let errMessage: string|null;\r\n                try{\r\n                    await be.inTransaction(null, async function(client){\r\n                        resultado+= await procedureGuardar.coreFunction(context, param_guardar, client);    \r\n                    })\r\n                }catch(err){\r\n                    errMessage = resultado + \"dm_forpkraiz_descargar. \"+ err ;\r\n                    resultado = errMessage\r\n                    console.log(errMessage)\r\n                }                \r\n                await context.client.query(\r\n                    `update tem\r\n                        set pase_tabla= $3\r\n                        where operativo= $1 and enc = $2\r\n                        returning 'ok'`\r\n                    ,\r\n                    [operativo, idEnc, resultado]\r\n                ).fetchUniqueRow();                \r\n\r\n            }).array());\r\n            return 'ok'\r\n        }\r\n    },\r\n    {\r\n        action:'dm_sincronizar',\r\n        parameters:[\r\n            {name:'persistentes'       , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            const ESTADO_POSTERIOR_CARGA = 'C';\r\n            const ESTADO_POSTERIOR_DESCARGA = 'D';\r\n            var be=context.be;\r\n            var {persistentes} = parameters;\r\n            var num_sincro:number=0;\r\n            var token:string|null=persistentes?.token;\r\n            if(!token){\r\n                token = (await be.procedure.token_get.coreFunction(context, {\r\n                    useragent: context.session.req.useragent, \r\n                    username: context.username\r\n                })).token;\r\n            }\r\n            var {value} = await context.client.query(`\r\n                INSERT INTO sincronizaciones (token, usuario, datos)\r\n                    VALUES ($1,$2,$3) \r\n                    RETURNING sincro\r\n                `, [token, context.username, persistentes]\r\n            ).fetchUniqueValue();\r\n            num_sincro=value;\r\n            var condviv= `\r\n                        tt.operativo= $1 \r\n                        and asignado = $2\r\n                        and tt.operacion='cargar' \r\n                        and (tt.cargado_dm is null or tt.cargado_dm = ${context.be.db.quoteLiteral(token)})\r\n            `\r\n            const UA_PRINCIPAL = await getUAPrincipal(context.client, OPERATIVO);\r\n            if(persistentes){\r\n                await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal, idEnc)=>{\r\n                    var tarea = persistentes.informacionHdr[idEnc].tarea.tarea;\r\n                    var puedoGuardarEnTEM=true;\r\n                    //TODO GENERALIZAR EL HORROR ESTE\r\n                    var setters=``;\r\n                    var params = [OPERATIVO, idEnc, tarea, token];\r\n                    if(tarea=='supe'){\r\n                        setters+= `, resumen_estado_sup=$5, norea_sup=$6, rea_sup=$7`\r\n                        params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);\r\n                    }else{\r\n                        setters+= `, resumen_estado=$5, norea=$6, rea=$7`\r\n                        params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);\r\n                    }\r\n                    var queryTareasTem = await context.client.query(\r\n                        `update tareas_tem\r\n                            set estado = ${context.be.db.quoteLiteral(ESTADO_POSTERIOR_DESCARGA)}, cargado_dm=null ${setters}\r\n                            where operativo= $1 and enc = $2 and tarea = $3 and cargado_dm = $4\r\n                            returning 'ok'`\r\n                        ,\r\n                        params\r\n                    ).fetchOneRowIfExists();\r\n                    puedoGuardarEnTEM=queryTareasTem.rowCount==1;\r\n                    if(puedoGuardarEnTEM){\r\n                        var {params, setters} = await getParametersAndSettersForUpdateTem(context, OPERATIVO, idEnc, respuestasUAPrincipal, tarea);\r\n                        await context.client.query(\r\n                            `update tem\r\n                                set ${setters}\r\n                                where operativo= $1 and enc = $2\r\n                                returning 'ok'`\r\n                            ,\r\n                            params\r\n                        ).fetchUniqueRow();\r\n\r\n                        //guardar paralelamente en tablas ua\r\n                        var procedureGuardar = be.procedure.caso_guardar;\r\n                        let resultado = `id enc ${idEnc}: `;\r\n                        let param_guardar={operativo: OPERATIVO,id_caso:idEnc, datos_caso:respuestasUAPrincipal}\r\n                        let errMessage: string|null;\r\n                        try{\r\n                            await be.inTransaction(null, async function(client){\r\n                                resultado+= await procedureGuardar.coreFunction(context, param_guardar, client);    \r\n                            })\r\n                        }catch(err){\r\n                            errMessage = resultado + \"dm_forpkraiz_descargar. \"+ err ;\r\n                            resultado = errMessage\r\n                            console.log(errMessage)\r\n                        }                \r\n                        await context.client.query(\r\n                            `update tem\r\n                                set pase_tabla= $3\r\n                                where operativo= $1 and enc = $2\r\n                                returning 'ok'`\r\n                            ,\r\n                            [OPERATIVO, idEnc, resultado]\r\n                        ).fetchUniqueRow();\r\n                    }else{\r\n                        await fs.appendFile('local-recibido-sin-token.txt', JSON.stringify({now:new Date(),user:context.username,idCaso: idEnc,vivienda: respuestasUAPrincipal})+'\\n\\n', 'utf8');\r\n                    }\r\n\r\n                }).array());\r\n            }\r\n            console.log(\"condviv: \", condviv);\r\n            console.log(\"query: \", getHdrQuery(condviv));\r\n            var {row} = await context.client.query(getHdrQuery(condviv),[OPERATIVO,context.user.idper]).fetchUniqueRow();\r\n            // console.log('xxxxxxxxxxxxxxxxxxxxxxxxxxx',getHdrQuery(condviv));\r\n            await context.client.query(\r\n                `update tareas_tem tt\r\n                    set  estado = $4, cargado_dm=$3::text\r\n                    where ${condviv} \r\n                    returning enc`\r\n                ,\r\n                [OPERATIVO, parameters.enc?parameters.enc:context.user.idper, token, ESTADO_POSTERIOR_CARGA]\r\n            ).fetchAll();\r\n            return {\r\n                ...row,\r\n                operativo: OPERATIVO, \r\n                soloLectura:false,\r\n                token,\r\n                num_sincro,\r\n                idper:context.user.idper,\r\n                cargas:likeAr.createIndex(row.cargas.map(carga=>({...carga, fecha:carga.fecha?date.iso(carga.fecha).toDmy():null, estado_carga:'relevamiento'})), 'carga')\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action:'dm_backup',\r\n        parameters:[\r\n            {name:'token'         , typeName:'text'},\r\n            {name:'tem'         , typeName:'jsonb'},\r\n        ],\r\n        unlogged:true,\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var {be, client} =context;\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            var num_sincro:number=0;\r\n            var token:string|null=parameters.token;\r\n            if(token == null){\r\n                return {ok:'ok:N/T'};\r\n            }else{\r\n                var {rowCount} = await client.query(`select 1 from tokens where token = $1`,[token]).fetchOneRowIfExists();\r\n                if(!rowCount){\r\n                    return {ok:'ok:N/T'};\r\n                }\r\n            }\r\n            if(parameters.tem){\r\n                await Promise.all(likeAr(parameters.tem).map(async (backup:any)=>{\r\n                    context.client.query(\r\n                        `update tem\r\n                            set json_backup = $3\r\n                            where operativo= $1 and enc = $2 and json_backup is distinct from $4\r\n                            returning 'ok'`\r\n                        ,\r\n                        [OPERATIVO, backup.forPkRaiz.vivienda, backup.respuestasRaiz, backup.respuestasRaiz]\r\n                    ).fetchOneRowIfExists();\r\n                }).array());\r\n            }\r\n            return {\r\n                ok:'ok'\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'consistir_vivienda',\r\n        parameters: [\r\n            {name:'operativo'     ,references:'operativos',  typeName:'text'},\r\n            {name:'vivienda'       ,typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var {be, client} =context;\r\n            let param_proc={\r\n                operativo: parameters.operativo,\r\n                id_caso: parameters.vivienda\r\n            } \r\n            let errMessage: string|null;\r\n            let resultado: string|null;\r\n            try{\r\n                resultado= await be.procedure.consistir_encuesta.coreFunction(context, \r\n                        param_proc, client\r\n                );    \r\n            }catch(err){\r\n                errMessage = \" consistir_vivienda. \"+ err ;\r\n                console.log(errMessage)\r\n            } \r\n            console.log('****** consistir_vivienda resultado:',resultado)               \r\n            return {\r\n                ok:'ok'\r\n            };\r\n        }\r\n\r\n    },\r\n    {\r\n        action: 'dm_rescatar',\r\n        parameters:[\r\n            {name:'localStorageItem'       , typeName:'jsonb'},\r\n            {name:'localStorageItemKey'    , typeName:'text'},\r\n        ],\r\n        unlogged:true,\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            var {localStorageItemKey, localStorageItem} = params;\r\n            try{\r\n                console.log(localStorageItem);\r\n                await fs.appendFile('local-rescate.txt', JSON.stringify({now:new Date(),user:context.username, itemKey: localStorageItemKey, itemData: localStorageItem})+'\\n\\n', 'utf8');\r\n                return 'ok';\r\n            }catch(err){\r\n                console.log('ERROR',err);\r\n                throw err;\r\n            }\r\n        }\r\n    },\r\n    {\r\n        action: 'operativo_get',\r\n        parameters:[],\r\n        unlogged:true,\r\n        coreFunction:async function(context:ProcedureContext, _parameters:CoreFunctionParameters){\r\n            return getOperativoActual(context)\r\n        }\r\n    },\r\n    {\r\n        action: 'get_random_free_case',\r\n        parameters:[{name:'operativo'    , typeName:'text'}],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            const minsToExpire = 30;\r\n            const minsSinceBloqued = `date_part('min', age(current_timestamp, fecha_bloqueo))`;\r\n            const enc = await context.client.query(`select enc from tem where operativo=$1 and (libre or ${minsSinceBloqued} > ${minsToExpire}) limit 1;`,[params.operativo]).fetchUniqueValue();\r\n            await context.client.query(`UPDATE tem set libre = false, fecha_bloqueo=current_timestamp where operativo=$1 and enc=$2`,[params.operativo, enc.value]).execute();\r\n            return enc.value;\r\n        }\r\n    },\r\n    {\r\n        action: 'accion_tareas_tem_ejecutar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n            {name:'condicion'       , typeName:'text'},\r\n            {name:'accion'          , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            var be =  context.be;\r\n            var accion = params.accion as EstadoAccion;\r\n            const ANALIZAR_CONDICION = true;\r\n            if(ANALIZAR_CONDICION){\r\n                var cumple:boolean = (await context.client.query(\r\n                    `select accion_cumple_condicion($5, $6, $7, $8, (\r\n                        select condicion \r\n                          from estados_acciones \r\n                          where operativo = $1 and estado = $2 and eaccion = $3 and estado_destino = $4\r\n                    )\r\n                )`, [\r\n                    params.operativo, \r\n                    accion.estado, \r\n                    accion.eaccion, \r\n                    accion.estado_destino,\r\n                    params.operativo, \r\n                    accion.estado, \r\n                    params.enc, \r\n                    accion.eaccion,\r\n                ])\r\n                .fetchUniqueValue()).value;\r\n                if(!cumple){\r\n                    throw Error(`No se pudo ejecutar la acción, no se cumple la condición \"${params.condicion}\" o bien el estado está desactualizado, refresque la grilla.`)\r\n                }\r\n            }\r\n            var result = await context.client.query(`\r\n                UPDATE tareas_tem \r\n                    set estado = $4\r\n                    where operativo=$1 \r\n                        and enc=$2 \r\n                        and tarea = $3\r\n                    returning *`,\r\n                [\r\n                    params.operativo, \r\n                    params.enc, \r\n                    params.tarea, \r\n                    accion.estado_destino\r\n                ]\r\n            ).fetchUniqueRow();\r\n            if(accion.nombre_procedure){\r\n                if(be.procedure[accion.nombre_procedure]){\r\n                    await be.procedure[accion.nombre_procedure].coreFunction(context, params)\r\n                }else{\r\n                    throw Error(`No existe el procedure \"${accion.nombre_procedure}\" definido en la tabla \"estados_acciones\" para el\r\n                    operativo: ${accion.operativo}, estado: ${accion.estado}, eaccion: ${accion.eaccion}.`)\r\n                }\r\n            }\r\n            return result.row;\r\n\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_carga_preparar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = 'cargar'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_disponibilizar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set asignado = null\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_no_cargar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = null\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_descarga_preparar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = 'descargar'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_no_descargar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = 'cargar'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_analizar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            var be = context.be;\r\n            await be.procedure.consistir_vivienda.coreFunction(context, {operativo:params.operativo, vivienda:params.enc})\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_verificar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set verificado = '1'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_no_verificar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set verificado = null\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_dpt',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            //TODO acá hay que preparar la siguiente tarea\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_habilitar_deshabilitar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tem\r\n                    set habilitada = not habilitada\r\n                    where operativo=$1 and enc=$2\r\n                    returning *`,\r\n                [params.operativo, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n      \r\n];\r\n"]}
998
+ returning *`, [params.operativo, params.enc])
999
+ .fetchUniqueRow();
1000
+ return 'ok';
1001
+ }
1002
+ },
1003
+ ];
1004
+ });
1005
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"procedures-dmencu.js","sourceRoot":"","sources":["../../../src/server/procedures-dmencu.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport { ProcedureDef, TableDefinition, Client } from \"./types-dmencu\";\r\nimport { ProcedureContext, CoreFunctionParameters, ForeignKey } from \"meta-enc\";\r\nimport * as likeAr from \"like-ar\";\r\nexport * from \"./types-dmencu\";\r\nimport { IdUnidadAnalisis, UnidadAnalisis, EstadoAccion } from \"../unlogged/tipos\";\r\n\r\nimport {json, jsono} from \"pg-promise-strict\";\r\n\r\nimport {changing, date } from 'best-globals';\r\nimport {promises as  fs} from \"fs\";\r\n\r\nimport * as ExpresionParser from 'expre-parser';\r\nimport { tareas } from \"./table-tareas\";\r\nimport { prependListener } from \"process\";\r\n\r\nvar path = require('path');\r\nvar sqlTools = require('sql-tools');\r\n\r\nvar discrepances = require('discrepances');\r\n\r\nconst formPrincipal = 'F:F1';\r\nconst MAIN_TABLENAME ='viviendas';\r\n\r\nexport const getOperativoActual = async (context:ProcedureContext)=>{\r\n    var be = context.be;\r\n    var result = await be.procedure.table_data.coreFunction(context,{table: `parametros`, fixedFields:[]});\r\n    if(result[0]?.operativo){\r\n        return result[0].operativo\r\n    }else{\r\n        throw Error ('no se configuró un operativo en la tabla parámetros');\r\n    }\r\n}\r\n\r\n\r\n/*definición de estructura completa, cuando exista ing-enc hay que ponerlo ahí*/ \r\ntype EstructuraTabla={tableName:string, pkFields:{fieldName:string}[], childTables:EstructuraTabla[]};\r\nfunction createStructure(context:ProcedureContext, tableName:string){\r\n    var be = context.be;\r\n    var mainTableDef:TableDefinition = be.tableStructures[tableName](context);\r\n    var getPkFromTableDef = function getPkFromTableDef(tableDef:TableDefinition){\r\n        return tableDef.primaryKey.map(function(pk){\r\n            return {fieldName:pk};\r\n        })\r\n    };\r\n    var getFkFromTableDef = function getFkFromTableDef(tableDef:TableDefinition, parentTableName: string){\r\n        // return tableDef.foreignKeys? tableDef.foreignKeys.map(fk=>fk.fields): [];\r\n        let parentFk = (<ForeignKey[]> tableDef.foreignKeys).find(fk=>fk.references == parentTableName);\r\n        return parentFk? parentFk.fields: [];\r\n    }\r\n    var struct:EstructuraTabla={\r\n        tableName:mainTableDef.name,\r\n        pkFields:getPkFromTableDef(mainTableDef),\r\n        childTables:[]\r\n    };\r\n    if(mainTableDef.detailTables && mainTableDef.detailTables.length){\r\n        mainTableDef.detailTables.forEach(function(detailTable){\r\n            struct.childTables.push(\r\n                changing(\r\n                    createStructure(context, detailTable.table),\r\n                    {fkFields: getFkFromTableDef(be.tableStructures[detailTable.table](context), tableName)}\r\n                )\r\n            );\r\n        })\r\n    }\r\n    return struct;\r\n}\r\n/* fin definicion estructura completa */\r\n\r\ntype AnyObject = {[k:string]:any}\r\n\r\nvar getParametersAndSettersForUpdateTem = async (context, operativo, idEnc, respuestasUAPrincipal, tarea)=>{\r\n    var registraEstadoEnTem = (await context.client.query(\r\n        `select registra_estado_en_tem\r\n            from tareas\r\n            where operativo=$1 and tarea = $2`\r\n        ,\r\n        [operativo, tarea]\r\n    ).fetchUniqueValue()).value;\r\n    var params = [operativo, idEnc, respuestasUAPrincipal]\r\n    var setters = `json_encuesta = $3`;\r\n    //TODO ARREGLAR ESTE HORROR, GENERALIZAR\r\n    if(tarea=='supe'){\r\n        setters+= `, resumen_estado_sup=$4, norea_sup=$5, rea_sup=$6`\r\n        params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);\r\n    }else{\r\n        setters+= `, resumen_estado=$4, norea=$5, rea=$6`\r\n        params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);\r\n    }\r\n    return {setters, params}\r\n}\r\n\r\nvar getHdrQuery =  function getHdrQuery(quotedCondViv:string){\r\n    return `\r\n    with viviendas as \r\n        (select t.enc, t.json_encuesta as respuestas, t.resumen_estado as \"resumenEstado\", \r\n            jsonb_build_object(\r\n                'dominio'       , dominio       ,\r\n                'nomcalle'      , nomcalle      ,\r\n                'sector'        , sector        ,\r\n                'edificio'      , edificio      ,\r\n                'entrada'       , entrada       ,\r\n                'nrocatastral'  , nrocatastral  ,\r\n                'piso'          , piso          ,\r\n                'departamento'  , departamento  ,\r\n                'habitacion'    , habitacion    ,\r\n                'casa'          , casa          ,\r\n                'prioridad'     , reserva+1     ,\r\n                'observaciones' , tt.carga_observaciones ,\r\n                'cita'          , cita ,\r\n                'carga'         , t.area         \r\n            ) as tem, t.area,\r\n            --TODO: GENERALIZAR\r\n            jsonb_build_object(\r\n                'tarea', tt.tarea,\r\n                'fecha_asignacion', fecha_asignacion,\r\n                'asignado', asignado,\r\n                'main_form', main_form\r\n            ) as tarea,\r\n            min(fecha_asignacion) as fecha_asignacion\r\n            from tem t left join tareas_tem tt on (t.operativo = tt.operativo and t.enc = tt.enc and t.tarea_actual = tt.tarea)\r\n                       left join tareas ta on t.tarea_actual = ta.tarea\r\n            where t.habilitada and ${quotedCondViv}\r\n            group by t.enc, t.json_encuesta, t.resumen_estado, dominio, nomcalle,sector,edificio, entrada, nrocatastral, piso,departamento,habitacion,casa,reserva,tt.carga_observaciones, cita, t.area, tt.tarea, fecha_asignacion, asignado, main_form\r\n        )\r\n        select jsonb_build_object(\r\n                'viviendas', ${jsono(\r\n                    `select enc, respuestas, jsonb_build_object('resumenEstado',\"resumenEstado\") as otras from viviendas`,\r\n                    'enc',\r\n                    `otras || coalesce(respuestas,'{}'::jsonb)`\r\n                )}\r\n            ) as respuestas,\r\n            ${json(`\r\n                select area as carga, observaciones_hdr as observaciones, min(fecha_asignacion) as fecha\r\n                    from viviendas inner join areas using (area) \r\n                    group by area, observaciones_hdr`, \r\n                'fecha')} as cargas,\r\n            ${jsono(\r\n                `select enc, jsonb_build_object('tem', tem, 'tarea', tarea) as otras from viviendas`,\r\n                 'enc',\r\n                 `otras ||'{}'::jsonb`\r\n                )}\r\n            as \"informacionHdr\"\r\n`\r\n}\r\n\r\nexport var setHdrQuery = (myFun:(quotedCondViv:string)=>string)=> getHdrQuery=myFun\r\n\r\nconst getUAPrincipal = async (client:Client, operativo:string)=>\r\n    (await client.query(\r\n        `select unidad_analisis\r\n            from unidad_analisis\r\n            where operativo= $1 and principal\r\n        `\r\n        ,\r\n        [operativo]\r\n    ).fetchUniqueValue()).value\r\n\r\nvar funcionesConocidas:{[k in string]:boolean} = {}\r\n\r\nvar compiler = new ExpresionParser.Compiler({\r\n    language:'js',\r\n    varWrapper:(var_name:string)=>`helpers.null2zero(valores.${var_name})`,\r\n    funWrapper:(functionName:string)=>{\r\n        if(!funcionesConocidas[functionName]){\r\n            console.log(functionName)\r\n            funcionesConocidas[functionName] = true;\r\n        }\r\n        return `helpers.funs.${functionName}`\r\n    }\r\n})\r\n\r\ntype CasilleroDeAca={\r\n    childs: CasilleroDeAca[],\r\n    data:{\r\n        expresion_habilitar: string\r\n        expresion_habilitar_js: string\r\n        especial: any\r\n        expresion_autoingresar_js: string\r\n    }\r\n}\r\n\r\nfunction compilarExpresion(expresion:string){\r\n    return compiler.toCode(ExpresionParser.parse(\r\n        expresion\r\n            .replace(/\\bis distinct from\\b/gi,' <> ')\r\n            .replace(/!!/gi,' ')\r\n    )).replace(/helpers\\.funs\\.blanco\\(helpers.null2zero\\(/g,'helpers.funs.blanco((')\r\n    .replace(/helpers\\.funs\\.informado\\(helpers.null2zero\\(/g,'helpers.funs.informado((');\r\n}\r\n\r\nfunction compilarExpresiones(casillero:CasilleroDeAca){\r\n    if(!casillero){ return }\r\n    if(casillero.data.expresion_habilitar){\r\n        casillero.data.expresion_habilitar_js = compilarExpresion(casillero.data.expresion_habilitar);\r\n    }\r\n    if(casillero.data.especial?.autoing){\r\n        var partes = casillero.data.especial?.autoing.split('=>');\r\n        if(partes.length>1){\r\n            var precondicion = partes[0];\r\n            var valor = partes.slice(1).join('=>');\r\n            casillero.data.expresion_autoingresar_js = `(${compilarExpresion(precondicion)})?(${compilarExpresion(valor)}):null`;\r\n        }else{\r\n            casillero.data.expresion_autoingresar_js = compilarExpresion(partes[0]);\r\n        }\r\n    }\r\n    for(var casilleroInterno of casillero.childs) compilarExpresiones(casilleroInterno);\r\n}\r\n\r\nexport const ProceduresDmEncu : ProcedureDef[] = [\r\n    {\r\n        action:'operativo_estructura_completa',\r\n        parameters:[\r\n            {name:'operativo'            ,typeName:'text', references:'operativos'},\r\n        ],\r\n        resultOk:'desplegarFormulario',\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be = context.be;\r\n            var result = await context.client.query(\r\n                `select casilleros_jerarquizados($1) as formularios, \r\n                    ${jsono(`select unidad_analisis, padre, pk_agregada, '{}'::jsonb as hijas from unidad_analisis`, 'unidad_analisis')} as unidades_analisis\r\n                `,\r\n                [parameters.operativo]\r\n            ).fetchUniqueRow();\r\n            likeAr(result.row.formularios).forEach(f=>compilarExpresiones(f));\r\n            // Hermanos son los formularios que están implantados en otro formulario de la misma UA. Por ejemplo el A1 en el S1\r\n            var resultHermanos = await context.client.query(`\r\nselect o.id_casillero as id_formulario, o.unidad_analisis, 'BF_'||o.casillero boton, bf.casillero, bf.padre, fp.casillero, fp.unidad_analisis\r\n  from casilleros o left join casilleros bf\r\n    on bf.tipoc='BF'\r\n\tand bf.casillero = 'BF_'||o.casillero\r\n\tand bf.operativo = o.operativo\r\n\tleft join casilleros fp\r\n\t  on fp.id_casillero = bf.padre\r\n\t  and fp.operativo = bf.operativo\r\n  where o.tipoc = 'F'\r\n    and o.unidad_analisis = fp.unidad_analisis\r\n\tand o.operativo = $1`,\r\n                [parameters.operativo]\r\n            ).fetchAll();\r\n            resultHermanos.rows.forEach(row=>{\r\n                result.row.formularios[row.id_formulario].data.hermano = true;\r\n            })\r\n            function completarUA(ua:UnidadAnalisis, idUa:IdUnidadAnalisis, uAs:{[k in IdUnidadAnalisis]: UnidadAnalisis}){\r\n                if(ua.padre){\r\n                    uAs[ua.padre].hijas[idUa] = ua;\r\n                }else{\r\n                    ua.principal=true;\r\n                }\r\n            }\r\n            likeAr(result.row.unidades_analisis).forEach((ua, idUa)=>\r\n                completarUA(ua, idUa as IdUnidadAnalisis, result.row.unidades_analisis)\r\n            )\r\n            var configSorteo = (await context.client.query(`\r\n                select config_sorteo \r\n                    from operativos \r\n                    where operativo = $1\r\n            `,[parameters.operativo]).fetchUniqueValue()).value;\r\n            let compilarExpresionesDominios = (expresionesDominio:any)=> \r\n                likeAr(expresionesDominio)\r\n                    .map((expr,dominio)=>({dominio, expr:compilarExpresion(expr.expr)}))\r\n                    .plain();\r\n            if(configSorteo){\r\n                likeAr(configSorteo).forEach((configSorteoFormulario)=>{\r\n                    configSorteoFormulario.expr_incompletitud_js=compilarExpresionesDominios(configSorteoFormulario.expr_incompletitud)\r\n                    configSorteoFormulario.filtro_js=compilarExpresionesDominios(configSorteoFormulario.filtro)\r\n                })\r\n            }\r\n            return {timestamp: be.timestampEstructura, ...result.row, operativo:parameters.operativo, configSorteo,noReas:be.caches.tableContent.no_rea, noReasSup:be.caches.tableContent.no_rea_sup};\r\n        }\r\n    },\r\n    {\r\n        action:'generar_formularios',\r\n        parameters:[\r\n            {name:'annio', typeName:'integer', references:'annio'},\r\n            {name:'mes'  , typeName:'integer', references:'mes'  },\r\n            {name:'lote' , typeName:'integer', references:'lotes'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be=context.be;\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            let resultUA = await context.client.query(\r\n                `select *\r\n                   from unidad_analisis\r\n                   where principal = true and operativo = $1\r\n                `,\r\n                [OPERATIVO]\r\n            ).fetchOneRowIfExists();\r\n            if (resultUA.rowCount === 0){\r\n                throw new Error('No se configuró una unidad de analisis como principal');\r\n            }\r\n            let row = resultUA.row;\r\n            let resultPreguntas = await be.procedure.preguntas_ua_traer.coreFunction(context, row)\r\n            var contenedorVacio:{[key:string]:any} = {};\r\n            resultPreguntas.forEach(function(defPregunta){\r\n                contenedorVacio[defPregunta.var_name] = defPregunta.unidad_analisis?[]:null;\r\n            });\r\n            contenedorVacio.annio= parameters.annio;\r\n            contenedorVacio.mes  = parameters.mes  ;\r\n            contenedorVacio.lote = parameters.lote ;\r\n            \r\n            var result = await context.client.query(\r\n                `select debe_haber.id_caso, s as id\r\n                    from (select lote, armar_id(annio, mes, lote, s) as id_caso, s\r\n                        from (select annio,mes,lote, cant_cues from lotes where (annio,mes,lote)=($2,$3,$4)) r, lateral generate_series(1,cant_cues) s\r\n                    ) debe_haber left join defgen hay on hay.id_caso = debe_haber.id_caso and hay.operativo=$1\r\n                    where hay.id_caso is null`,\r\n                [ OPERATIVO, parameters.annio, parameters.mes, parameters.lote]\r\n            ).fetchAll();\r\n            var params = {operativo: OPERATIVO};\r\n            for(var i=0; i < result.rowCount; i++){\r\n                await be.procedure.caso_guardar.coreFunction(\r\n                    context, \r\n                    changing(params,{id_caso:result.rows[i].id_caso, datos_caso:changing(contenedorVacio,{id:result.rows[i].id})})\r\n                )\r\n            }\r\n            return {agregadas:result.rowCount}\r\n        }\r\n    },\r\n    {\r\n        action:'upload_file',\r\n        progress: true,\r\n        parameters:[\r\n            {name: 'id_adjunto', typeName: 'integer'},\r\n            {name: 'nombre', typeName: 'text'},\r\n        ],\r\n        files:{count:1},\r\n        coreFunction:function(context:ProcedureContext, parameters:CoreFunctionParameters, files){\r\n            let be=context.be;\r\n            let client=context.client;\r\n            context.informProgress({message:be.messages.fileUploaded});\r\n            let file = files[0]\r\n            let ext = path.extname(file.path).substr(1);\r\n            let originalFilename = file.originalFilename.slice(0,-(ext.length+1));\r\n            let filename= parameters.nombre || originalFilename;\r\n            let newPath = 'local-attachments/file-';\r\n            var createResponse = function createResponse(adjuntoRow){\r\n                let resultado = {\r\n                    message: 'La subida se realizó correctamente (update)',\r\n                    nombre: adjuntoRow.nombre,\r\n                    nombre_original: adjuntoRow.nombre_original,\r\n                    ext: adjuntoRow.ext,\r\n                    fecha: adjuntoRow.fecha,\r\n                    hora: adjuntoRow.hora,\r\n                    id_adjunto: adjuntoRow.id_adjunto\r\n                }\r\n                return resultado\r\n            }\r\n            var moveFile = function moveFile(file, id_adjunto, extension){\r\n                fs.move(file.path, newPath + id_adjunto + '.' + extension, { overwrite: true });\r\n            }\r\n            return Promise.resolve().then(function(){\r\n                if(parameters.id_adjunto){\r\n                    return context.client.query(`update adjuntos set nombre= $1,nombre_original = $2, ext = $3, ruta = concat('local-attachments/file-',$4::text,'.',$3::text), fecha = now(), hora = date_trunc('seconds',current_timestamp-current_date)\r\n                        where id_adjunto = $4 returning *`,\r\n                        [filename, originalFilename, ext, parameters.id_adjunto]\r\n                    ).fetchUniqueRow().then(function(result){\r\n                        return createResponse(result.row)\r\n                    }).then(function(resultado){\r\n                        moveFile(file,resultado.id_adjunto,resultado.ext);\r\n                        return resultado\r\n                    });\r\n                }else{\r\n                    return context.client.query(`insert into adjuntos (nombre, nombre_original, ext, fecha, hora) values ($1,$2,$3,now(), date_trunc('seconds',current_timestamp-current_date)) returning *`,\r\n                        [filename, originalFilename, ext]\r\n                    ).fetchUniqueRow().then(function(result){\r\n                        return context.client.query(`update adjuntos set ruta = concat('local-attachments/file-',id_adjunto::text,'.',ext)\r\n                            where id_adjunto = $1 returning *`,\r\n                            [result.row.id_adjunto]\r\n                        ).fetchUniqueRow().then(function(result){\r\n                            return createResponse(result.row)\r\n                        }).then(function(resultado){\r\n                            moveFile(file,resultado.id_adjunto,resultado.ext);\r\n                            return resultado\r\n                        });\r\n                    });\r\n                }\r\n            }).catch(function(err){\r\n                throw err;\r\n            });\r\n        }\r\n    },\r\n    {\r\n        action:'caso_guardar',\r\n        parameters:[\r\n            {name:'operativo'   , typeName:'text', references:'operativos'},\r\n            {name:'id_caso'     , typeName:'text'      },\r\n            {name:'datos_caso'  , typeName:'jsonb'     },\r\n        ],\r\n        definedIn: 'dmencu',\r\n        //@ts-ignore especifico el tipo de los parámetros\r\n        coreFunction:async function(context:ProcedureContext, parameters:{\r\n            operativo:string, \r\n            id_caso:string,\r\n            datos_caso:AnyObject\r\n        },newClient:Client){\r\n            var client=newClient || context.client;\r\n            var datos_json=parameters.datos_caso;\r\n            var be = context.be;\r\n            var tableStructures_app:TableDefinitions = be.tableStructures;\r\n        \r\n            var struct_dmencu = createStructure(context, MAIN_TABLENAME);\r\n            datos_json['operativo'] = parameters.operativo;\r\n            //TODO : vivienda ó enc???\r\n            datos_json['vivienda'] = parameters.id_caso;\r\n            function completar_ult_pk_en_arr( ult_pk, ua_arr){\r\n                var con_pk_completa=ua_arr; \r\n                if (ua_arr && ua_arr.length>=1){\r\n                    con_pk_completa= con_pk_completa.map((una_ua,i)=>{\r\n                        una_ua[ult_pk]=i+1   \r\n                        return una_ua;\r\n                    })\r\n                };\r\n                return con_pk_completa\r\n            }\r\n            for( var key1 in datos_json ){\r\n                var dato_key1 = datos_json[key1];\r\n                if ( dato_key1 instanceof Array && dato_key1.length >= 1 ) {\r\n                    var pk1 = tableStructures_app[key1](context).primaryKey;\r\n                    var ult_pk1 = pk1[pk1.length-1];\r\n                    datos_json[key1] = completar_ult_pk_en_arr( ult_pk1, datos_json[key1]) \r\n                    datos_json[key1].forEach((un_key1, i1)=>{\r\n                        for ( var key2 in un_key1 ){\r\n                            if ( un_key1[key2] instanceof Array && un_key1[key2].length >= 1 ){\r\n                                var pk2 = tableStructures_app[key2](context).primaryKey;\r\n                                var ult_pk2 = pk2[pk2.length-1];            \r\n                                datos_json[key1][i1][key2] = completar_ult_pk_en_arr( ult_pk2, datos_json[key1][i1][key2])\r\n                                datos_json[key1][i1][key2].forEach(un_key2=>{\r\n                                    Object.keys(un_key2).filter( p2=>p2.startsWith('$')).forEach(pp2=>\r\n                                        delete un_key2[pp2]\r\n                                    )                                        \r\n                                })\r\n                            }\r\n                            if (key2.startsWith('$')||key2.startsWith('_')){\r\n                                delete datos_json[key1][i1][key2];\r\n                            }\r\n                        }\r\n                    });\r\n                }\r\n                if (key1.startsWith('$')){\r\n                    delete datos_json[key1];\r\n                };\r\n            }\r\n            \r\n            delete datos_json.codRea;\r\n            delete datos_json.codNoRea;\r\n            delete datos_json.resumenEstado;\r\n            delete datos_json.codReaSup;\r\n            delete datos_json.codNoReaSup;\r\n            delete datos_json.resumenEstadoSup;\r\n\r\n            if( Object.keys(datos_json).length >2){\r\n                var queries = sqlTools.structuredData.sqlWrite(datos_json, struct_dmencu);\r\n                return await queries.reduce(function(promise, query){\r\n                    return promise.then(function() {\r\n                        return client.query(query).execute().then(function(result){\r\n                            return 'ok';\r\n                        });\r\n                    });\r\n                },Promise.resolve()).then(function(){\r\n                    return \"ok\";\r\n                }).catch(function(err:Error){\r\n                    console.log(\"caso_guardar ENTRA EN EL CATCH: \",err)\r\n                    throw err\r\n                })\r\n            }else{\r\n                return 'vacio';\r\n            }    \r\n        }\r\n    },\r\n    {\r\n        action: 'caso_traer',\r\n        parameters: [\r\n            //{name:'formulario'    ,                          typeName:'text'},\r\n            {name:'operativo'     ,references:'operativos',  typeName:'text'},\r\n            {name:'id_caso'       ,typeName:'text'},\r\n        ],\r\n        resultOk: 'goToEnc',\r\n        definedIn: 'dmencu',\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var client=context.client;\r\n             var struct_dmencu = createStructure(context, MAIN_TABLENAME);\r\n            var sql = sqlTools.structuredData.sqlRead({operativo: parameters.operativo, vivienda:parameters.id_caso}, struct_dmencu);\r\n            var result = await client.query(sql).fetchUniqueValue();\r\n            var response = {\r\n                operativo: parameters.operativo,\r\n                vivienda: parameters.id_caso,\r\n                datos_caso: result.value,\r\n                //formulario: formPrincipal,\r\n            };\r\n            return response;\r\n        }\r\n    },\r\n    {\r\n        action: 'caso_traer_o_crear',\r\n        parameters: [\r\n            {name:'operativo'     ,references:'operativos',  typeName:'text'},\r\n            {name:'id_caso'       ,typeName:'text'},\r\n        ],\r\n        resultOk: 'goToEnc',\r\n        // bitacora:{always:true},\r\n        coreFunction:async function(context:ProcedureContext, parameters:CoreFunctionParameters){\r\n            var be = context.be;\r\n            try{\r\n                var result = await be.procedure['caso_traer'].coreFunction(context, parameters);\r\n                return result\r\n            }catch(err){\r\n                var json = await be.procedure['caso_preparar'].coreFunction(context, parameters);\r\n                await be.procedure['caso_guardar'].coreFunction(context, changing(parameters, {datos_caso:json}));\r\n                return await be.procedure['caso_traer'].coreFunction(context, parameters);\r\n            }\r\n        }\r\n    },\r\n    {\r\n        action:'pasar_json2ua',\r\n        parameters:[\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, _parameters:CoreFunctionParameters){\r\n            /* GENERALIZAR: */\r\n            var be=context.be;\r\n            /* FIN-GENERALIZAR: */\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            let resultMain = await context.client.query(`SELECT * FROM ${MAIN_TABLENAME} LIMIT 1`).fetchAll();\r\n            if(resultMain.rowCount>0){\r\n                console.log('HAY DATOS',resultMain.rows)\r\n                throw new Error('HAY DATOS. NO SE PUEDE INICIAR EL PASAJE');\r\n            }\r\n            let resultJson = await context.client.query(\r\n                `SELECT operativo, enc id_caso, json_encuesta datos_caso from tem \r\n                    WHERE operativo=$1 and resumen_estado is distinct from 'vacio' and json_encuesta is not null \r\n                    order by enc `,\r\n                [OPERATIVO]\r\n            ).fetchAll();\r\n            var procedureGuardar = be.procedure.caso_guardar;\r\n            if(procedureGuardar.definedIn!='dmencu'){\r\n                throw new Error('hay que sobreescribir caso_guardar');\r\n            }\r\n            return Promise.all(resultJson.rows.map(async function(row){\r\n                let resultado = `id caso ${row.id_caso}: `;\r\n                try{\r\n                    await be.inTransaction(null, async function(client){\r\n                        resultado+= await procedureGuardar.coreFunction(context, row, client);    \r\n                    })\r\n                }catch(err){\r\n                    let errMessage = resultado + \"json2ua error. \"+ err ;\r\n                    resultado = errMessage\r\n                    console.log(errMessage)\r\n                }     \r\n                if(resultado.includes('ok')){ \r\n                    var {datos_caso, vivienda, operativo} = await be.procedure.caso_traer.coreFunction(context, {operativo:row.operativo, id_caso:row.id_caso})\r\n                    var verQueGrabo = {datos_caso, vivienda, operativo}\r\n                    try{\r\n                        discrepances.showAndThrow(verQueGrabo,row)\r\n                    }catch(err){\r\n                        console.log(verQueGrabo,row)\r\n                    }\r\n                }\r\n                return resultado;\r\n            })).catch(function(err){\r\n                throw err;\r\n            }).then(function(result){\r\n                return result;\r\n            })\r\n        }\r\n    },\r\n    {\r\n        action:'dm_forpkraiz_cargar',\r\n        parameters:[\r\n            {name:'operativo'         , typeName:'text'},\r\n            {name:'vivienda'          , typeName:'text'},\r\n            {name:'tarea'             , typeName:'text', references:\"tareas\"},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var be=context.be;\r\n            var {operativo,vivienda, tarea} = parameters;\r\n            var main_form = (await context.client.query(\r\n                `select main_form\r\n                    from tareas\r\n                    where operativo= $1 and tarea=$2`\r\n                ,\r\n                [operativo, tarea]\r\n            ).fetchUniqueValue()).value;\r\n            var condviv= ` t.operativo= $1 and t.enc =$2`;\r\n            var soloLectura = !!(await context.client.query(\r\n                `select *\r\n                    from tareas_tem join estados using (operativo, estado) --pk estado verificada\r\n                    where operativo= $1 and enc = $2 and (cargado_dm is not null or not permite_editar_encuesta)`\r\n                ,\r\n                [operativo, vivienda]\r\n            ).fetchOneRowIfExists()).rowCount;\r\n            var {row} = await context.client.query(getHdrQuery(condviv),[operativo,vivienda]).fetchUniqueRow();\r\n            row.informacionHdr[vivienda].tarea={\r\n                tarea,\r\n                main_form\r\n            } ;\r\n            return {\r\n                ...row,\r\n                operativo,\r\n                soloLectura,\r\n                idPer:context.user.idper,\r\n                cargas:likeAr.createIndex(row.cargas.map(carga=>({...carga, fecha:carga.fecha?date.iso(carga.fecha).toDmy():null})), 'carga'),\r\n                timestampEstructura:be.timestampEstructura\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action:'dm_forpkraiz_descargar',\r\n        parameters:[\r\n            {name:'operativo'         , typeName:'text'},\r\n            {name:'persistentes'      , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var be=context.be;\r\n            var {operativo, persistentes} = parameters;\r\n            const UA_PRINCIPAL = await getUAPrincipal(context.client, operativo);\r\n            await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal,idEnc)=>{\r\n                if(respuestasUAPrincipal.s1a1_obs == '!prueba de error al grabar!'){\r\n                    throw new Error('DIO PRUEBA DE ERROR AL GRABAR');\r\n                }\r\n                var {params, setters} = await getParametersAndSettersForUpdateTem(context, operativo, idEnc, respuestasUAPrincipal, persistentes.informacionHdr[idEnc].tarea.tarea);\r\n                await context.client.query(\r\n                    `update tem\r\n                        set ${setters}\r\n                        where operativo= $1 and enc = $2\r\n                        returning 'ok'`\r\n                    ,\r\n                    params\r\n                ).fetchUniqueRow();\r\n                //guardar paralelamente en tablas ua\r\n                var procedureGuardar = be.procedure.caso_guardar;\r\n                let resultado = `id enc ${idEnc}: `;\r\n                let param_guardar={operativo: operativo,id_caso:idEnc, datos_caso:respuestasUAPrincipal}\r\n                let errMessage: string|null;\r\n                try{\r\n                    await be.inTransaction(null, async function(client){\r\n                        resultado+= await procedureGuardar.coreFunction(context, param_guardar, client);    \r\n                    })\r\n                }catch(err){\r\n                    errMessage = resultado + \"dm_forpkraiz_descargar. \"+ err ;\r\n                    resultado = errMessage\r\n                    console.log(errMessage)\r\n                }                \r\n                await context.client.query(\r\n                    `update tem\r\n                        set pase_tabla= $3\r\n                        where operativo= $1 and enc = $2\r\n                        returning 'ok'`\r\n                    ,\r\n                    [operativo, idEnc, resultado]\r\n                ).fetchUniqueRow();                \r\n\r\n            }).array());\r\n            return 'ok'\r\n        }\r\n    },\r\n    {\r\n        action:'dm_sincronizar',\r\n        parameters:[\r\n            {name:'persistentes'       , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            const ESTADO_POSTERIOR_CARGA = 'C';\r\n            const ESTADO_POSTERIOR_DESCARGA = 'D';\r\n            var be=context.be;\r\n            var {persistentes} = parameters;\r\n            var num_sincro:number=0;\r\n            var token:string|null=persistentes?.token;\r\n            if(!token){\r\n                token = (await be.procedure.token_get.coreFunction(context, {\r\n                    useragent: context.session.req.useragent, \r\n                    username: context.username\r\n                })).token;\r\n            }\r\n            var {value} = await context.client.query(`\r\n                INSERT INTO sincronizaciones (token, usuario, datos)\r\n                    VALUES ($1,$2,$3) \r\n                    RETURNING sincro\r\n                `, [token, context.username, persistentes]\r\n            ).fetchUniqueValue();\r\n            num_sincro=value;\r\n            var condviv= `\r\n                        tt.operativo= $1 \r\n                        and asignado = $2\r\n                        and tt.operacion='cargar' \r\n                        and (tt.cargado_dm is null or tt.cargado_dm = ${context.be.db.quoteLiteral(token)})\r\n            `\r\n            const UA_PRINCIPAL = await getUAPrincipal(context.client, OPERATIVO);\r\n            if(persistentes){\r\n                await Promise.all(likeAr(persistentes.respuestas[UA_PRINCIPAL]).map(async (respuestasUAPrincipal, idEnc)=>{\r\n                    var tarea = persistentes.informacionHdr[idEnc].tarea.tarea;\r\n                    var puedoGuardarEnTEM=true;\r\n                    //TODO GENERALIZAR EL HORROR ESTE\r\n                    var setters=``;\r\n                    var params = [OPERATIVO, idEnc, tarea, token];\r\n                    if(tarea=='supe'){\r\n                        setters+= `, resumen_estado_sup=$5, norea_sup=$6, rea_sup=$7`\r\n                        params = params.concat([respuestasUAPrincipal.resumenEstadoSup, respuestasUAPrincipal.codNoReaSup, respuestasUAPrincipal.codReaSup]);\r\n                    }else{\r\n                        setters+= `, resumen_estado=$5, norea=$6, rea=$7`\r\n                        params = params.concat([respuestasUAPrincipal.resumenEstado, respuestasUAPrincipal.codNoRea, respuestasUAPrincipal.codRea]);\r\n                    }\r\n                    var queryTareasTem = await context.client.query(\r\n                        `update tareas_tem\r\n                            set estado = ${context.be.db.quoteLiteral(ESTADO_POSTERIOR_DESCARGA)}, cargado_dm=null ${setters}\r\n                            where operativo= $1 and enc = $2 and tarea = $3 and cargado_dm = $4\r\n                            returning 'ok'`\r\n                        ,\r\n                        params\r\n                    ).fetchOneRowIfExists();\r\n                    puedoGuardarEnTEM=queryTareasTem.rowCount==1;\r\n                    if(puedoGuardarEnTEM){\r\n                        var {params, setters} = await getParametersAndSettersForUpdateTem(context, OPERATIVO, idEnc, respuestasUAPrincipal, tarea);\r\n                        await context.client.query(\r\n                            `update tem\r\n                                set ${setters}\r\n                                where operativo= $1 and enc = $2\r\n                                returning 'ok'`\r\n                            ,\r\n                            params\r\n                        ).fetchUniqueRow();\r\n\r\n                        //guardar paralelamente en tablas ua\r\n                        var procedureGuardar = be.procedure.caso_guardar;\r\n                        let resultado = `id enc ${idEnc}: `;\r\n                        let param_guardar={operativo: OPERATIVO,id_caso:idEnc, datos_caso:respuestasUAPrincipal}\r\n                        let errMessage: string|null;\r\n                        try{\r\n                            await be.inTransaction(null, async function(client){\r\n                                resultado+= await procedureGuardar.coreFunction(context, param_guardar, client);    \r\n                            })\r\n                        }catch(err){\r\n                            errMessage = resultado + \"dm_forpkraiz_descargar. \"+ err ;\r\n                            resultado = errMessage\r\n                            console.log(errMessage)\r\n                        }                \r\n                        await context.client.query(\r\n                            `update tem\r\n                                set pase_tabla= $3\r\n                                where operativo= $1 and enc = $2\r\n                                returning 'ok'`\r\n                            ,\r\n                            [OPERATIVO, idEnc, resultado]\r\n                        ).fetchUniqueRow();\r\n                    }else{\r\n                        await fs.appendFile('local-recibido-sin-token.txt', JSON.stringify({now:new Date(),user:context.username,idCaso: idEnc,vivienda: respuestasUAPrincipal})+'\\n\\n', 'utf8');\r\n                    }\r\n\r\n                }).array());\r\n            }\r\n            console.log(\"condviv: \", condviv);\r\n            console.log(\"query: \", getHdrQuery(condviv));\r\n            var {row} = await context.client.query(getHdrQuery(condviv),[OPERATIVO,context.user.idper]).fetchUniqueRow();\r\n            // console.log('xxxxxxxxxxxxxxxxxxxxxxxxxxx',getHdrQuery(condviv));\r\n            await context.client.query(\r\n                `update tareas_tem tt\r\n                    set  estado = $4, cargado_dm=$3::text\r\n                    where ${condviv} \r\n                    returning enc`\r\n                ,\r\n                [OPERATIVO, parameters.enc?parameters.enc:context.user.idper, token, ESTADO_POSTERIOR_CARGA]\r\n            ).fetchAll();\r\n            return {\r\n                ...row,\r\n                operativo: OPERATIVO, \r\n                soloLectura:false,\r\n                token,\r\n                num_sincro,\r\n                idper:context.user.idper,\r\n                cargas:likeAr.createIndex(row.cargas.map(carga=>({...carga, fecha:carga.fecha?date.iso(carga.fecha).toDmy():null, estado_carga:'relevamiento'})), 'carga')\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action:'dm_backup',\r\n        parameters:[\r\n            {name:'token'         , typeName:'text'},\r\n            {name:'tem'         , typeName:'jsonb'},\r\n        ],\r\n        unlogged:true,\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var {be, client} =context;\r\n            const OPERATIVO = await getOperativoActual(context);\r\n            var num_sincro:number=0;\r\n            var token:string|null=parameters.token;\r\n            if(token == null){\r\n                return {ok:'ok:N/T'};\r\n            }else{\r\n                var {rowCount} = await client.query(`select 1 from tokens where token = $1`,[token]).fetchOneRowIfExists();\r\n                if(!rowCount){\r\n                    return {ok:'ok:N/T'};\r\n                }\r\n            }\r\n            if(parameters.tem){\r\n                await Promise.all(likeAr(parameters.tem).map(async (backup:any)=>{\r\n                    context.client.query(\r\n                        `update tem\r\n                            set json_backup = $3\r\n                            where operativo= $1 and enc = $2 and json_backup is distinct from $4\r\n                            returning 'ok'`\r\n                        ,\r\n                        [OPERATIVO, backup.forPkRaiz.vivienda, backup.respuestasRaiz, backup.respuestasRaiz]\r\n                    ).fetchOneRowIfExists();\r\n                }).array());\r\n            }\r\n            return {\r\n                ok:'ok'\r\n            };\r\n        }\r\n    },\r\n    {\r\n        action: 'consistir_vivienda',\r\n        parameters: [\r\n            {name:'operativo'     ,references:'operativos',  typeName:'text'},\r\n            {name:'vivienda'       ,typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context: ProcedureContext, parameters: CoreFunctionParameters){\r\n            var {be, client} =context;\r\n            let param_proc={\r\n                operativo: parameters.operativo,\r\n                id_caso: parameters.vivienda\r\n            } \r\n            let errMessage: string|null;\r\n            let resultado: string|null;\r\n            try{\r\n                resultado= await be.procedure.consistir_encuesta.coreFunction(context, \r\n                        param_proc, client\r\n                );    \r\n            }catch(err){\r\n                errMessage = \" consistir_vivienda. \"+ err ;\r\n                console.log(errMessage)\r\n            } \r\n            console.log('****** consistir_vivienda resultado:',resultado)               \r\n            return {\r\n                ok:'ok'\r\n            };\r\n        }\r\n\r\n    },\r\n    {\r\n        action: 'dm_rescatar',\r\n        parameters:[\r\n            {name:'localStorageItem'       , typeName:'jsonb'},\r\n            {name:'localStorageItemKey'    , typeName:'text'},\r\n        ],\r\n        unlogged:true,\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            var {localStorageItemKey, localStorageItem} = params;\r\n            try{\r\n                console.log(localStorageItem);\r\n                await fs.appendFile('local-rescate.txt', JSON.stringify({now:new Date(),user:context.username, itemKey: localStorageItemKey, itemData: localStorageItem})+'\\n\\n', 'utf8');\r\n                return 'ok';\r\n            }catch(err){\r\n                console.log('ERROR',err);\r\n                throw err;\r\n            }\r\n        }\r\n    },\r\n    {\r\n        action: 'operativo_get',\r\n        parameters:[],\r\n        unlogged:true,\r\n        coreFunction:async function(context:ProcedureContext, _parameters:CoreFunctionParameters){\r\n            return getOperativoActual(context)\r\n        }\r\n    },\r\n    {\r\n        action: 'get_random_free_case',\r\n        parameters:[{name:'operativo'    , typeName:'text'}],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            const minsToExpire = 30;\r\n            const minsSinceBloqued = `date_part('min', age(current_timestamp, fecha_bloqueo))`;\r\n            const enc = await context.client.query(`select enc from tem where operativo=$1 and (libre or ${minsSinceBloqued} > ${minsToExpire}) limit 1;`,[params.operativo]).fetchUniqueValue();\r\n            await context.client.query(`UPDATE tem set libre = false, fecha_bloqueo=current_timestamp where operativo=$1 and enc=$2`,[params.operativo, enc.value]).execute();\r\n            return enc.value;\r\n        }\r\n    },\r\n    {\r\n        action: 'accion_tareas_tem_ejecutar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n            {name:'condicion'       , typeName:'text'},\r\n            {name:'accion'          , typeName:'jsonb'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            var be =  context.be;\r\n            var accion = params.accion as EstadoAccion;\r\n            const ANALIZAR_CONDICION = true;\r\n            if(ANALIZAR_CONDICION){\r\n                var cumple:boolean = (await context.client.query(\r\n                    `select accion_cumple_condicion($5, $6, $7, $8, (\r\n                        select condicion \r\n                          from estados_acciones \r\n                          where operativo = $1 and estado = $2 and eaccion = $3 and estado_destino = $4\r\n                    )\r\n                )`, [\r\n                    params.operativo, \r\n                    accion.estado, \r\n                    accion.eaccion, \r\n                    accion.estado_destino,\r\n                    params.operativo, \r\n                    accion.estado, \r\n                    params.enc, \r\n                    accion.eaccion,\r\n                ])\r\n                .fetchUniqueValue()).value;\r\n                if(!cumple){\r\n                    throw Error(`No se pudo ejecutar la acción, no se cumple la condición \"${params.condicion}\" o bien el estado está desactualizado, refresque la grilla.`)\r\n                }\r\n            }\r\n            var result = await context.client.query(`\r\n                UPDATE tareas_tem \r\n                    set estado = $4\r\n                    where operativo=$1 \r\n                        and enc=$2 \r\n                        and tarea = $3\r\n                    returning *`,\r\n                [\r\n                    params.operativo, \r\n                    params.enc, \r\n                    params.tarea, \r\n                    accion.estado_destino\r\n                ]\r\n            ).fetchUniqueRow();\r\n            if(accion.nombre_procedure){\r\n                if(be.procedure[accion.nombre_procedure]){\r\n                    await be.procedure[accion.nombre_procedure].coreFunction(context, params)\r\n                }else{\r\n                    throw Error(`No existe el procedure \"${accion.nombre_procedure}\" definido en la tabla \"estados_acciones\" para el\r\n                    operativo: ${accion.operativo}, estado: ${accion.estado}, eaccion: ${accion.eaccion}.`)\r\n                }\r\n            }\r\n            return result.row;\r\n\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_carga_preparar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = 'cargar'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_disponibilizar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set asignado = null\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_no_cargar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = null\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_descarga_preparar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = 'descargar'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_no_descargar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set operacion = 'cargar'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_analizar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            var be = context.be;\r\n            await be.procedure.consistir_encuesta.coreFunction(context, {operativo:params.operativo, id_caso:params.enc})\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_verificar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set verificado = '1'\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_no_verificar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tareas_tem\r\n                    set verificado = null\r\n                    where operativo=$1 and tarea= $2 and enc=$3\r\n                    returning *`,\r\n                [params.operativo, params.tarea, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_dpt',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'tarea'           , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            //TODO acá hay que preparar la siguiente tarea\r\n            return 'ok';\r\n        }\r\n    },\r\n    {\r\n        action: 'encuesta_habilitar_deshabilitar',\r\n        parameters:[\r\n            {name:'operativo'       , typeName:'text'},\r\n            {name:'enc'             , typeName:'text'},\r\n        ],\r\n        coreFunction:async function(context:ProcedureContext, params:CoreFunctionParameters){\r\n            await context.client.query(`\r\n                UPDATE tem\r\n                    set habilitada = not habilitada\r\n                    where operativo=$1 and enc=$2\r\n                    returning *`,\r\n                [params.operativo, params.enc])\r\n            .fetchUniqueRow();\r\n            return 'ok';\r\n        }\r\n    },\r\n      \r\n];\r\n"]}