dmencu 0.7.30 → 0.8.0

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.
@@ -19,6 +19,7 @@
19
19
  var db = be.db;
20
20
  var puedeEditar = context.forDump || ((_c = (_b = context.puede) === null || _b === void 0 ? void 0 : _b.campo) === null || _c === void 0 ? void 0 : _c.administrar) || context.user.rol === 'recepcionista';
21
21
  var camposCorte = [{ name: 'cluster', typeName: 'integer' }, ...(opts.camposCorte || [])];
22
+ var tieneSeleccionado = context.be.caches.tableContent.conReaHogar.config_sorteo;
22
23
  var camposCalculados = [
23
24
  { name: 'no_salieron', typeName: 'bigint', aggregate: 'sum', title: 'no salieron a campo', condicion: `resumen_estado is null` },
24
25
  { name: 'salieron', typeName: 'bigint', aggregate: 'sum', title: 'salieron a campo' },
@@ -66,8 +67,11 @@
66
67
  --TODO REVISAR
67
68
  round(rea*100.0/nullif( ${(['rea', ...(camposCalculados.filter(f => f.tasa_efectividad).map(f => f.name))].join('+'))},0),1) as tasa_efectividad,
68
69
  total-coalesce(no_salieron,0) as salieron,
69
- coalesce(otros,0) + ${opts.gabinete ? ` coalesce(otras_causas,0) ` : opts.sinhogfin ? ` coalesce(otras_causas_seleccionado,0)+coalesce(otras_causas_vivienda,0)` : ` coalesce(otras_causas_hogar,0)+coalesce(otras_causas_seleccionado,0)+coalesce(otras_causas_vivienda,0)`} as otras_causas_gabinete,
70
- coalesce(pendiente,0)+coalesce(mixta,0) +coalesce(sin_resultado,0) + ${opts.gabinete ? ` coalesce(incompleto,0) ` : opts.gabinete && !opts.sinhogfin ? ` coalesce(no_finalizada,0) ` : !opts.gabinete && !opts.sinhogfin ? `coalesce(sin_finalizar_dm,0)+ coalesce(sin_finalizar_incompleto,0) + coalesce(sin_finalizar_otra_causa,0)` : `0`} as en_curso
70
+ coalesce(otros,0) + ${opts.gabinete ? ` coalesce(otras_causas,0) ` : opts.sinhogfin ? ` coalesce(otras_causas_seleccionado,0)+coalesce(otras_causas_vivienda,0)` : !tieneSeleccionado ? ` coalesce(otras_causas_hogar,0) +coalesce(otras_causas_vivienda,0)` : ` coalesce(otras_causas_hogar,0) +coalesce(otras_causas_vivienda,0)+ coalesce(otras_causas_seleccionado,0)`} as otras_causas_gabinete,
71
+ coalesce(pendiente,0)+coalesce(mixta,0) +coalesce(sin_resultado,0) +coalesce(incompleto,0) +${opts.gabinete && tieneSeleccionado && !opts.sinhogfin ? ` coalesce(no_finalizada,0) ` : !opts.gabinete && !opts.sinhogfin && tieneSeleccionado ? `coalesce(sin_finalizar_dm,0)+ coalesce(sin_finalizar_incompleto,0) + coalesce(sin_finalizar_otra_causa,0)` : `0`} as en_curso
72
+ /* coalesce(otros,0)+${opts.gabinete ? `coalesce(otras_causas,0) ` : `coalesce(otras_causas_hogar,0) + coalesce(otras_causas_seleccionado,0) + coalesce(otras_causas_vivienda,0)`} as otras_causas_gabinete, */
73
+ /* coalesce(pendiente,0)+coalesce(mixta,0)+ coalesce(incompleto,0)+coalesce(sin_resultado,0)+${opts.gabinete ? `coalesce(no_finalizada,0)` : `coalesce(sin_finalizar_dm,0)+coalesce(sin_finalizar_incompleto,0)+ coalesce(sin_finalizar_otra_causa,0)`} as en_curso */
74
+
71
75
  from (
72
76
  select ${[
73
77
  ...camposCorte.map(f => f.name),
@@ -102,4 +106,4 @@
102
106
  }
103
107
  exports.control_campo = control_campo;
104
108
  });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-control_campo.js","sourceRoot":"","sources":["../../../src/server/table-control_campo.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport { stringify } from \"querystring\";\r\nimport {TableDefinition, TableContext, FieldDefinition} from \"./types-dmencu\";\r\n\r\nexport type controlCamposOpts={\r\n    nombre:string, \r\n    agrupador?:string, \r\n    agrupado?:boolean,\r\n    camposCorte?:FieldDefinition[],\r\n    filtroWhere?:string\r\n    title?:string\r\n    gabinete?:boolean\r\n    sinhogfin?:boolean\r\n}\r\n\r\n\r\nexport function control_campo(context:TableContext,opts?:controlCamposOpts):TableDefinition {\r\n    opts = opts || {nombre:'control_campo'}\r\n    opts.agrupador = opts.agrupador || 'no_rea_groups'\r\n    opts.agrupado = opts.agrupado ?? false\r\n    var be=context.be;\r\n    var db=be.db;\r\n    var puedeEditar = context.forDump || context.puede?.campo?.administrar||context.user.rol==='recepcionista';\r\n    var camposCorte:FieldDefinition[]=[{name:'cluster'       , typeName:'integer'},...(\r\n        opts.camposCorte ||[]\r\n    )];\r\n\r\n    var camposCalculados:(FieldDefinition & {condicion:string, tasa_efectividad:boolean})[]=[\r\n        {name:'no_salieron'  , typeName:'bigint', aggregate:'sum', title:'no salieron a campo', condicion:`resumen_estado is null`},\r\n        {name:'salieron'     , typeName:'bigint', aggregate:'sum', title:'salieron a campo'},\r\n        {name:'sin_novedad'  , typeName:'bigint', aggregate:'sum', visible:opts.agrupado},\r\n        {name:'sin_resultado', typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('vacio')`},\r\n       // {name:'cita_pactada' , typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('cita pactada')`},\r\n        {name:'rea'          , typeName:'bigint', aggregate:'sum', condicion:`resultado='efectiva'`},\r\n        {name:'pendiente'    , typeName:'bigint', aggregate:'sum', condicion:`resultado='pendiente'`},\r\n        {name:'mixta'        , typeName:'bigint', aggregate:'sum', condicion:`resultado='mixta'`},\r\n        /*\r\n        {name:'asuente_viv'  , typeName:'bigint', title:'ausente de vivienda', condicion:`cod_no_rea=7`},\r\n        {name:'asuente_mie'  , typeName:'bigint', title:'ausente de miembro seleccionado', condicion:`cod_no_rea=75`},\r\n        */\r\n        ...(be.caches.tableContent[opts.agrupador]||[]).map(g=>({\r\n            name:g.grupo.replace(/ /g,'_'),\r\n            typeName:'bigint',\r\n            inTable:false,\r\n            title:g.grupo,\r\n            condicion:`cod_no_rea in (${g.codigos.map(c=>db.quoteLiteral(c.no_rea)).join(',')})`,\r\n            aggregate:'sum',\r\n            tasa_efectividad:!g.codigos[0].grupo0.startsWith('no encuestable')\r\n        }))\r\n    ];\r\n    return {\r\n        name:opts.nombre,\r\n        editable:false,\r\n        title:opts.title||opts.nombre.replace(/_/g,' '),\r\n        fields:[\r\n            ...camposCorte,\r\n            {name:'total'        , typeName:'bigint', aggregate:'sum'},\r\n            ...camposCalculados.map(f=>{var {condicion, ...fieldDef}=f; return fieldDef}),\r\n            {name:'otros'                    , typeName:'bigint', aggregate:'sum'},\r\n            {name:'tasa_efectividad'         , typeName:'decimal'},\r\n            {name:'incompleto'               , typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('incompleto','con problemas')`},\r\n            {name:'verif_encu_pendiente'     , typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('incompleto','con problemas')`},\r\n            {name:'en_curso'                 , typeName:'bigint', aggregate:'sum', visible:!!opts.gabinete, title:'En_curso'     },\r\n            {name:'otras_causas_gabinete'    , typeName:'bigint', aggregate:'sum', visible:!!opts.gabinete, title: 'Otras_causas'},\r\n        ],\r\n        primaryKey:camposCorte.map(f=>f.name),\r\n        sql:{\r\n            isTable:false,\r\n            from:` \r\n            ( \r\n                select t.*, coalesce(incompleto,0)+coalesce(sin_resultado,0) as sin_novedad,\r\n                        --TODO REVISAR\r\n                        round(rea*100.0/nullif( ${(\r\n                            ['rea', ...(camposCalculados.filter(f=>f.tasa_efectividad).map(f=>f.name))].join('+')\r\n                        )},0),1) as tasa_efectividad,\r\n                        total-coalesce(no_salieron,0) as salieron,\r\n                        coalesce(otros,0) + ${opts.gabinete?` coalesce(otras_causas,0) `:opts.sinhogfin?` coalesce(otras_causas_seleccionado,0)+coalesce(otras_causas_vivienda,0)`: ` coalesce(otras_causas_hogar,0)+coalesce(otras_causas_seleccionado,0)+coalesce(otras_causas_vivienda,0)`}  as otras_causas_gabinete,\r\n                        coalesce(pendiente,0)+coalesce(mixta,0) +coalesce(sin_resultado,0) + ${ opts.gabinete? ` coalesce(incompleto,0) `: opts.gabinete && !opts.sinhogfin? ` coalesce(no_finalizada,0) `: !opts.gabinete && !opts.sinhogfin? `coalesce(sin_finalizar_dm,0)+ coalesce(sin_finalizar_incompleto,0) + coalesce(sin_finalizar_otra_causa,0)` :`0`} as en_curso\r\n                    from (   \r\n                        select ${[\r\n                            ...camposCorte.map(f=>f.name),\r\n                            `count(*) as total`,\r\n                            ...camposCalculados.filter(f=>f.condicion).map(f=>`\r\n                            count(*) filter (where klase=${db.quoteLiteral(f.name)}) as ${f.name}`),\r\n                            'count(*) filter (where klase is null) as otros'\r\n                        ].join(',')}\r\n                            , count(*) filter (where resumen_estado in ('incompleto','con problemas')) as incompleto\r\n                            , count(*) filter (where resumen_estado in ('no rea','ok') and verificado is null) as verif_encu_pendiente\r\n                        from (\r\n                            select t.*,a.participacion_a, a.clase_a, \r\n                                case ${camposCalculados.filter(f=>f.condicion).map(f=>\r\n                                    `when ${f.condicion} then ${db.quoteLiteral(f.name)} \r\n                                    `\r\n                                    ).join('')} else null end as klase\r\n                                from (\r\n                                    select t.*, tt.verificado, t.norea as cod_no_rea\r\n                                        from tem t left join comunas c on t.nrocomuna=c.comuna\r\n                                            left join tareas_tem tt on t.operativo=tt.operativo and t.enc=tt.enc and tt.tarea='encu'\r\n\r\n                                    where ${opts.filtroWhere || 'true'}    \r\n                                ) t left join (select area, string_agg(distinct participacion::text, ', ' order by participacion::text desc ) as participacion_a\r\n                                    , string_agg(distinct clase, ', ' order by clase desc ) as clase_a\r\n                                    from tem\r\n                                    group by 1                            \r\n                                ) a  using  (area )\r\n                        ) t\r\n                        ${camposCorte.length?`group by ${camposCorte.map(f=>f.name)}`:''}\r\n                    ) t\r\n            )`\r\n        }\r\n    };\r\n}\r\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-control_campo.js","sourceRoot":"","sources":["../../../src/server/table-control_campo.ts"],"names":[],"mappings":";;;;;;;;;IAAA,YAAY,CAAC;;;IAiBb,SAAgB,aAAa,CAAC,OAAoB,EAAC,IAAuB;;QACtE,IAAI,GAAG,IAAI,IAAI,EAAC,MAAM,EAAC,eAAe,EAAC,CAAA;QACvC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,eAAe,CAAA;QAClD,IAAI,CAAC,QAAQ,GAAG,MAAA,IAAI,CAAC,QAAQ,mCAAI,KAAK,CAAA;QACtC,IAAI,EAAE,GAAC,OAAO,CAAC,EAAE,CAAC;QAClB,IAAI,EAAE,GAAC,EAAE,CAAC,EAAE,CAAC;QACb,IAAI,WAAW,GAAG,OAAO,CAAC,OAAO,KAAI,MAAA,MAAA,OAAO,CAAC,KAAK,0CAAE,KAAK,0CAAE,WAAW,CAAA,IAAE,OAAO,CAAC,IAAI,CAAC,GAAG,KAAG,eAAe,CAAC;QAC3G,IAAI,WAAW,GAAmB,CAAC,EAAC,IAAI,EAAC,SAAS,EAAS,QAAQ,EAAC,SAAS,EAAC,EAAC,GAAG,CAC9E,IAAI,CAAC,WAAW,IAAG,EAAE,CACxB,CAAC,CAAC;QACH,IAAI,iBAAiB,GAAC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,aAAa,CAAC;QAC/E,IAAI,gBAAgB,GAAoE;YACpF,EAAC,IAAI,EAAC,aAAa,EAAI,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,KAAK,EAAC,qBAAqB,EAAE,SAAS,EAAC,wBAAwB,EAAC;YAC3H,EAAC,IAAI,EAAC,UAAU,EAAO,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,KAAK,EAAC,kBAAkB,EAAC;YACpF,EAAC,IAAI,EAAC,aAAa,EAAI,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,IAAI,CAAC,QAAQ,EAAC;YACjF,EAAC,IAAI,EAAC,eAAe,EAAE,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAC,6BAA6B,EAAC;YAC5H,sIAAsI;YACrI,EAAC,IAAI,EAAC,KAAK,EAAY,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,SAAS,EAAC,sBAAsB,EAAC;YAC5F,EAAC,IAAI,EAAC,WAAW,EAAM,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,SAAS,EAAC,uBAAuB,EAAC;YAC7F,EAAC,IAAI,EAAC,OAAO,EAAU,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,SAAS,EAAC,mBAAmB,EAAC;YACzF;;;cAGE;YACF,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC;gBACpD,IAAI,EAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAC,GAAG,CAAC;gBAC9B,QAAQ,EAAC,QAAQ;gBACjB,OAAO,EAAC,KAAK;gBACb,KAAK,EAAC,CAAC,CAAC,KAAK;gBACb,SAAS,EAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG;gBACpF,SAAS,EAAC,KAAK;gBACf,gBAAgB,EAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,gBAAgB,CAAC;aACrE,CAAC,CAAC;SACN,CAAC;QACF,OAAO;YACH,IAAI,EAAC,IAAI,CAAC,MAAM;YAChB,QAAQ,EAAC,KAAK;YACd,KAAK,EAAC,IAAI,CAAC,KAAK,IAAE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,EAAC,GAAG,CAAC;YAC/C,MAAM,EAAC;gBACH,GAAG,WAAW;gBACd,EAAC,IAAI,EAAC,OAAO,EAAU,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAC;gBAC1D,GAAG,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,GAAC,IAAI,EAAC,SAAS,EAAE,GAAG,QAAQ,EAAC,GAAC,CAAC,CAAC,CAAC,OAAO,QAAQ,CAAA,CAAA,CAAC,CAAC;gBAC7E,EAAC,IAAI,EAAC,OAAO,EAAsB,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAC;gBACtE,EAAC,IAAI,EAAC,kBAAkB,EAAW,QAAQ,EAAC,SAAS,EAAC;gBACtD,EAAC,IAAI,EAAC,YAAY,EAAiB,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAC,kDAAkD,EAAC;gBAC5J,EAAC,IAAI,EAAC,sBAAsB,EAAO,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAC,kDAAkD,EAAC;gBAC5J,EAAC,IAAI,EAAC,UAAU,EAAmB,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAC,UAAU,EAAM;gBACtH,EAAC,IAAI,EAAC,uBAAuB,EAAM,QAAQ,EAAC,QAAQ,EAAE,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,cAAc,EAAC;aACzH;YACD,UAAU,EAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,IAAI,CAAC;YACrC,GAAG,EAAC;gBACA,OAAO,EAAC,KAAK;gBACb,IAAI,EAAC;;;;kDAIiC,CACtB,CAAC,KAAK,EAAE,GAAG,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACxF;;8CAEqB,IAAI,CAAC,QAAQ,CAAA,CAAC,CAAA,4BAA4B,CAAA,CAAC,CAAA,IAAI,CAAC,SAAS,CAAA,CAAC,CAAA,0EAA0E,CAAA,CAAC,CAAC,CAAC,iBAAiB,CAAA,CAAC,CAAA,oEAAoE,CAAA,CAAC,CAAA,2GAA2G;sHAChQ,IAAI,CAAC,QAAQ,IAAI,iBAAiB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,6BAA6B,CAAA,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,iBAAiB,CAAA,CAAC,CAAC,2GAA2G,CAAC,CAAC,CAAA,GAAG;8CACxU,IAAI,CAAC,QAAQ,CAAA,CAAC,CAAA,2BAA2B,CAAA,CAAC,CAAA,4GAA4G;sHAC9E,IAAI,CAAC,QAAQ,CAAA,CAAC,CAAA,2BAA2B,CAAA,CAAC,CAAA,yGAAyG;;;iCAGxO;oBACL,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,IAAI,CAAC;oBAC7B,mBAAmB;oBACnB,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA;2DACnB,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC;oBACvE,gDAAgD;iBACnD,CAAC,IAAI,CAAC,GAAG,CAAC;;;;;uCAKI,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAClD,QAAQ,CAAC,CAAC,SAAS,SAAS,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC;qCAClD,CACA,CAAC,IAAI,CAAC,EAAE,CAAC;;;;;;4CAMF,IAAI,CAAC,WAAW,IAAI,MAAM;;;;;;;0BAO5C,WAAW,CAAC,MAAM,CAAA,CAAC,CAAA,YAAY,WAAW,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,CAAC,CAAC,IAAI,CAAC,EAAE,CAAA,CAAC,CAAA,EAAE;;cAE1E;aACL;SACJ,CAAC;IACN,CAAC;IAlGD,sCAkGC","sourcesContent":["\"use strict\";\r\n\r\nimport { stringify } from \"querystring\";\r\nimport {TableDefinition, TableContext, FieldDefinition} from \"./types-dmencu\";\r\n\r\nexport type controlCamposOpts={\r\n    nombre:string, \r\n    agrupador?:string, \r\n    agrupado?:boolean,\r\n    camposCorte?:FieldDefinition[],\r\n    filtroWhere?:string\r\n    title?:string\r\n    gabinete?:boolean\r\n    sinhogfin?:boolean\r\n}\r\n\r\n\r\nexport function control_campo(context:TableContext,opts?:controlCamposOpts):TableDefinition {\r\n    opts = opts || {nombre:'control_campo'}\r\n    opts.agrupador = opts.agrupador || 'no_rea_groups'\r\n    opts.agrupado = opts.agrupado ?? false\r\n    var be=context.be;\r\n    var db=be.db;\r\n    var puedeEditar = context.forDump || context.puede?.campo?.administrar||context.user.rol==='recepcionista';\r\n    var camposCorte:FieldDefinition[]=[{name:'cluster'       , typeName:'integer'},...(\r\n        opts.camposCorte ||[]\r\n    )];\r\n    var tieneSeleccionado=context.be.caches.tableContent.conReaHogar.config_sorteo;\r\n    var camposCalculados:(FieldDefinition & {condicion:string, tasa_efectividad:boolean})[]=[\r\n        {name:'no_salieron'  , typeName:'bigint', aggregate:'sum', title:'no salieron a campo', condicion:`resumen_estado is null`},\r\n        {name:'salieron'     , typeName:'bigint', aggregate:'sum', title:'salieron a campo'},\r\n        {name:'sin_novedad'  , typeName:'bigint', aggregate:'sum', visible:opts.agrupado},\r\n        {name:'sin_resultado', typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('vacio')`},\r\n       // {name:'cita_pactada' , typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('cita pactada')`},\r\n        {name:'rea'          , typeName:'bigint', aggregate:'sum', condicion:`resultado='efectiva'`},\r\n        {name:'pendiente'    , typeName:'bigint', aggregate:'sum', condicion:`resultado='pendiente'`},\r\n        {name:'mixta'        , typeName:'bigint', aggregate:'sum', condicion:`resultado='mixta'`},\r\n        /*\r\n        {name:'asuente_viv'  , typeName:'bigint', title:'ausente de vivienda', condicion:`cod_no_rea=7`},\r\n        {name:'asuente_mie'  , typeName:'bigint', title:'ausente de miembro seleccionado', condicion:`cod_no_rea=75`},\r\n        */\r\n        ...(be.caches.tableContent[opts.agrupador]||[]).map(g=>({\r\n            name:g.grupo.replace(/ /g,'_'),\r\n            typeName:'bigint',\r\n            inTable:false,\r\n            title:g.grupo,\r\n            condicion:`cod_no_rea in (${g.codigos.map(c=>db.quoteLiteral(c.no_rea)).join(',')})`,\r\n            aggregate:'sum',\r\n            tasa_efectividad:!g.codigos[0].grupo0.startsWith('no encuestable')\r\n        }))\r\n    ];\r\n    return {\r\n        name:opts.nombre,\r\n        editable:false,\r\n        title:opts.title||opts.nombre.replace(/_/g,' '),\r\n        fields:[\r\n            ...camposCorte,\r\n            {name:'total'        , typeName:'bigint', aggregate:'sum'},\r\n            ...camposCalculados.map(f=>{var {condicion, ...fieldDef}=f; return fieldDef}),\r\n            {name:'otros'                    , typeName:'bigint', aggregate:'sum'},\r\n            {name:'tasa_efectividad'         , typeName:'decimal'},\r\n            {name:'incompleto'               , typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('incompleto','con problemas')`},\r\n            {name:'verif_encu_pendiente'     , typeName:'bigint', aggregate:'sum', visible:!opts.agrupado, condicion:`resumen_estado in ('incompleto','con problemas')`},\r\n            {name:'en_curso'                 , typeName:'bigint', aggregate:'sum', visible:!!opts.gabinete, title:'En_curso'     },\r\n            {name:'otras_causas_gabinete'    , typeName:'bigint', aggregate:'sum', visible:!!opts.gabinete, title: 'Otras_causas'},\r\n        ],\r\n        primaryKey:camposCorte.map(f=>f.name),\r\n        sql:{\r\n            isTable:false,\r\n            from:` \r\n            ( \r\n                select t.*, coalesce(incompleto,0)+coalesce(sin_resultado,0) as sin_novedad,\r\n                        --TODO REVISAR\r\n                        round(rea*100.0/nullif( ${(\r\n                            ['rea', ...(camposCalculados.filter(f=>f.tasa_efectividad).map(f=>f.name))].join('+')\r\n                        )},0),1) as tasa_efectividad,\r\n                        total-coalesce(no_salieron,0) as salieron,\r\n                        coalesce(otros,0) + ${opts.gabinete?` coalesce(otras_causas,0) `:opts.sinhogfin?` coalesce(otras_causas_seleccionado,0)+coalesce(otras_causas_vivienda,0)`: !tieneSeleccionado?` coalesce(otras_causas_hogar,0) +coalesce(otras_causas_vivienda,0)`:` coalesce(otras_causas_hogar,0) +coalesce(otras_causas_vivienda,0)+ coalesce(otras_causas_seleccionado,0)`}  as otras_causas_gabinete,\r\n                        coalesce(pendiente,0)+coalesce(mixta,0) +coalesce(sin_resultado,0) +coalesce(incompleto,0) +${ opts.gabinete && tieneSeleccionado && !opts.sinhogfin ? ` coalesce(no_finalizada,0) `: !opts.gabinete && !opts.sinhogfin && tieneSeleccionado? `coalesce(sin_finalizar_dm,0)+ coalesce(sin_finalizar_incompleto,0) + coalesce(sin_finalizar_otra_causa,0)` :`0`} as en_curso\r\n                     /*   coalesce(otros,0)+${opts.gabinete?`coalesce(otras_causas,0) `:`coalesce(otras_causas_hogar,0) + coalesce(otras_causas_seleccionado,0) + coalesce(otras_causas_vivienda,0)`}  as otras_causas_gabinete, */\r\n                     /*   coalesce(pendiente,0)+coalesce(mixta,0)+ coalesce(incompleto,0)+coalesce(sin_resultado,0)+${opts.gabinete?`coalesce(no_finalizada,0)`:`coalesce(sin_finalizar_dm,0)+coalesce(sin_finalizar_incompleto,0)+ coalesce(sin_finalizar_otra_causa,0)`}  as en_curso */\r\n\r\n                    from (   \r\n                        select ${[\r\n                            ...camposCorte.map(f=>f.name),\r\n                            `count(*) as total`,\r\n                            ...camposCalculados.filter(f=>f.condicion).map(f=>`\r\n                            count(*) filter (where klase=${db.quoteLiteral(f.name)}) as ${f.name}`),\r\n                            'count(*) filter (where klase is null) as otros'\r\n                        ].join(',')}\r\n                            , count(*) filter (where resumen_estado in ('incompleto','con problemas')) as incompleto\r\n                            , count(*) filter (where resumen_estado in ('no rea','ok') and verificado is null) as verif_encu_pendiente\r\n                        from (\r\n                            select t.*,a.participacion_a, a.clase_a, \r\n                                case ${camposCalculados.filter(f=>f.condicion).map(f=>\r\n                                    `when ${f.condicion} then ${db.quoteLiteral(f.name)} \r\n                                    `\r\n                                    ).join('')} else null end as klase\r\n                                from (\r\n                                    select t.*, tt.verificado, t.norea as cod_no_rea\r\n                                        from tem t left join comunas c on t.nrocomuna=c.comuna\r\n                                            left join tareas_tem tt on t.operativo=tt.operativo and t.enc=tt.enc and tt.tarea='encu'\r\n\r\n                                    where ${opts.filtroWhere || 'true'}    \r\n                                ) t left join (select area, string_agg(distinct participacion::text, ', ' order by participacion::text desc ) as participacion_a\r\n                                    , string_agg(distinct clase, ', ' order by clase desc ) as clase_a\r\n                                    from tem\r\n                                    group by 1                            \r\n                                ) a  using  (area )\r\n                        ) t\r\n                        ${camposCorte.length?`group by ${camposCorte.map(f=>f.name)}`:''}\r\n                    ) t\r\n            )`\r\n        }\r\n    };\r\n}\r\n"]}
@@ -23,6 +23,7 @@
23
23
  { name: 'tarea_actual', typeName: 'text', editable: false },
24
24
  { name: 'recepcionista', typeName: 'text', editable: false, inTable: false },
25
25
  { name: 'asignado', typeName: 'text', editable: false, inTable: false },
26
+ { name: 'estado', typeName: 'text', editable: false, nullable: false },
26
27
  { name: 'area', typeName: 'integer', editable: false },
27
28
  { name: 'zona', typeName: 'text', editable: false },
28
29
  { name: 'codcalle', typeName: 'integer', editable: false },
@@ -69,7 +70,7 @@
69
70
  sql: {
70
71
  isTable: false,
71
72
  from: `(
72
- select t.*, recepcionista, asignado
73
+ select t.*, recepcionista, asignado, estado
73
74
  from tem t
74
75
  inner join tareas_tem tt
75
76
  on (t.operativo=tt.operativo and t.enc=tt.enc and t.tarea_actual=tt.tarea)
@@ -80,4 +81,4 @@
80
81
  }
81
82
  exports.grilla_hoja_ruta = grilla_hoja_ruta;
82
83
  });
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-grilla_hoja_ruta.js","sourceRoot":"","sources":["../../../src/server/table-grilla_hoja_ruta.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport {TableDefinition, TableContext, FieldDefinition, OtherTableDefs} from \"./types-dmencu\";\r\n\r\nexport function grilla_hoja_ruta(context:TableContext):TableDefinition {\r\n    //var be=context.be;\r\n    var puedeEditar = false;\r\n    return {   \r\n        name:'grilla_hoja_ruta',\r\n        elementName:'hdr',\r\n        editable:puedeEditar,\r\n        fields:[\r\n            {name:'operativo'            , typeName:'text'    , editable: false  , nullable: false, defaultValue: 'etoi211'},\r\n            {name:'enc'                  , typeName:'text'    , editable: false  , nullable: false                       },\r\n            {name:'tarea_actual'         , typeName:'text'    , editable: false  },\r\n            {name:'recepcionista'        , typeName:'text'    , editable: false , inTable: false  },\r\n            {name:'asignado'             , typeName:'text'    , editable: false , inTable: false  },\r\n            {name:'area'                 , typeName:'integer' , editable: false  },\r\n            {name:'zona'                 , typeName:'text'    , editable: false  },\r\n            {name:'codcalle'             , typeName:'integer' , editable: false  },\r\n            {name:'nomcalle'             , typeName:'text'    , editable: false  },\r\n            {name:'nrocatastral'         , typeName:'integer' , editable: false  },\r\n            {name:'piso'                 , typeName:'text'    , editable: false  },\r\n            {name:'departamento'         , typeName:'text'    , editable: false  },\r\n            {name:'habitacion'           , typeName:'text'    , editable: false  },\r\n            {name:'sector'               , typeName:'text'    , editable: false  },\r\n            {name:'edificio'             , typeName:'text'    , editable: false  },\r\n            {name:'entrada'              , typeName:'text'    , editable: false  },\r\n            {name:'barrio'               , typeName:'text'    , editable: false  },\r\n            {name:'codpos'               , typeName:'integer' , editable: false  },\r\n           // {name:'dominio'              , typeName:'integer' , editable: false  },\r\n            {name:'nrocomuna'            , typeName:'integer' , editable: false  },\r\n            {name:'nrofraccion'          , typeName:'integer' , editable: false  },\r\n            {name:'nroradio'             , typeName:'integer' , editable: false  },\r\n            {name:'nromanzana'           , typeName:'integer' , editable: false  },\r\n            {name:'nrolado'              , typeName:'integer' , editable: false  },\r\n           // {name:'usodomicilio'         , typeName:'integer' , editable: false  },\r\n           // {name:'participacion'        , typeName:'integer' , editable: false  ,visible: true  },\r\n           // {name:'rotacion'             , typeName:'integer' , editable: false  ,visible: false  },\r\n           // {name:'clase'                , typeName:'text'    , editable: false  ,visible: false  },\r\n           // {name:'panel'                , typeName:'integer' , editable: false  ,visible: false  },\r\n            {name:'casa'                 , typeName:'text'    , editable: false  },\r\n            // concatenadas en obs\r\n           // {name:'obsdatosdomicilio'    , typeName:'text'    , editable: false  },\r\n           // {name:'obsconjunto'          , typeName:'text'    , editable: false  },\r\n           // {name:'reserva'              , typeName:'integer' , editable: false  },\r\n            {name:'semana'               , typeName:'integer' , editable: false  ,visible: true   },\r\n           // {name:'periodicidad'         , typeName:'text'    , editable: false  ,visible: true   },\r\n            {name:'obs'                  , typeName:'text'    , editable: false  },\r\n    ],\r\n        primaryKey:[\"operativo\",'enc'],\r\n        foreignKeys:[\r\n            {references:'areas'   , fields:['operativo', 'area']},\r\n            {references:'tareas' , fields:[\r\n                {source:'operativo', target:'operativo'},\r\n                {source:'tarea_actual', target:'tarea'}\r\n            ],\r\n                alias:'latarea'\r\n            },\r\n          ],   \r\n        sql:{\r\n            isTable:false,\r\n            from:`(\r\n                select t.*, recepcionista, asignado\r\n                    from tem t\r\n                    inner join tareas_tem tt\r\n                    on (t.operativo=tt.operativo and  t.enc=tt.enc  and t.tarea_actual=tt.tarea)\r\n                    order by t.enc\r\n            )`,\r\n        }\r\n\r\n    };\r\n}"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-grilla_hoja_ruta.js","sourceRoot":"","sources":["../../../src/server/table-grilla_hoja_ruta.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport {TableDefinition, TableContext, FieldDefinition, OtherTableDefs} from \"./types-dmencu\";\r\n\r\nexport function grilla_hoja_ruta(context:TableContext):TableDefinition {\r\n    //var be=context.be;\r\n    var puedeEditar = false;\r\n    return {   \r\n        name:'grilla_hoja_ruta',\r\n        elementName:'hdr',\r\n        editable:puedeEditar,\r\n        fields:[\r\n            {name:'operativo'            , typeName:'text'    , editable: false  , nullable: false, defaultValue: 'etoi211'},\r\n            {name:'enc'                  , typeName:'text'    , editable: false  , nullable: false                       },\r\n            {name:'tarea_actual'         , typeName:'text'    , editable: false  },\r\n            {name:'recepcionista'        , typeName:'text'    , editable: false , inTable: false  },\r\n            {name:'asignado'             , typeName:'text'    , editable: false , inTable: false  },\r\n            {name:'estado'               , typeName:'text'    , editable: false , nullable: false },\r\n            {name:'area'                 , typeName:'integer' , editable: false  },\r\n            {name:'zona'                 , typeName:'text'    , editable: false  },\r\n            {name:'codcalle'             , typeName:'integer' , editable: false  },\r\n            {name:'nomcalle'             , typeName:'text'    , editable: false  },\r\n            {name:'nrocatastral'         , typeName:'integer' , editable: false  },\r\n            {name:'piso'                 , typeName:'text'    , editable: false  },\r\n            {name:'departamento'         , typeName:'text'    , editable: false  },\r\n            {name:'habitacion'           , typeName:'text'    , editable: false  },\r\n            {name:'sector'               , typeName:'text'    , editable: false  },\r\n            {name:'edificio'             , typeName:'text'    , editable: false  },\r\n            {name:'entrada'              , typeName:'text'    , editable: false  },\r\n            {name:'barrio'               , typeName:'text'    , editable: false  },\r\n            {name:'codpos'               , typeName:'integer' , editable: false  },\r\n           // {name:'dominio'              , typeName:'integer' , editable: false  },\r\n            {name:'nrocomuna'            , typeName:'integer' , editable: false  },\r\n            {name:'nrofraccion'          , typeName:'integer' , editable: false  },\r\n            {name:'nroradio'             , typeName:'integer' , editable: false  },\r\n            {name:'nromanzana'           , typeName:'integer' , editable: false  },\r\n            {name:'nrolado'              , typeName:'integer' , editable: false  },\r\n           // {name:'usodomicilio'         , typeName:'integer' , editable: false  },\r\n           // {name:'participacion'        , typeName:'integer' , editable: false  ,visible: true  },\r\n           // {name:'rotacion'             , typeName:'integer' , editable: false  ,visible: false  },\r\n           // {name:'clase'                , typeName:'text'    , editable: false  ,visible: false  },\r\n           // {name:'panel'                , typeName:'integer' , editable: false  ,visible: false  },\r\n            {name:'casa'                 , typeName:'text'    , editable: false  },\r\n            // concatenadas en obs\r\n           // {name:'obsdatosdomicilio'    , typeName:'text'    , editable: false  },\r\n           // {name:'obsconjunto'          , typeName:'text'    , editable: false  },\r\n           // {name:'reserva'              , typeName:'integer' , editable: false  },\r\n            {name:'semana'               , typeName:'integer' , editable: false  ,visible: true   },\r\n           // {name:'periodicidad'         , typeName:'text'    , editable: false  ,visible: true   },\r\n            {name:'obs'                  , typeName:'text'    , editable: false  },\r\n    ],\r\n        primaryKey:[\"operativo\",'enc'],\r\n        foreignKeys:[\r\n            {references:'areas'   , fields:['operativo', 'area']},\r\n            {references:'tareas' , fields:[\r\n                {source:'operativo', target:'operativo'},\r\n                {source:'tarea_actual', target:'tarea'}\r\n            ],\r\n                alias:'latarea'\r\n            },\r\n          ],   \r\n        sql:{\r\n            isTable:false,\r\n            from:`(\r\n                select t.*, recepcionista, asignado, estado\r\n                    from tem t\r\n                    inner join tareas_tem tt\r\n                    on (t.operativo=tt.operativo and  t.enc=tt.enc  and t.tarea_actual=tt.tarea)\r\n                    order by t.enc\r\n            )`,\r\n        }\r\n\r\n    };\r\n}"]}
@@ -0,0 +1,3 @@
1
+ /// <reference types="backend-plus" />
2
+ import { TableDefinition, TableContext } from "./types-dmencu";
3
+ export declare function tareas_proximas(context: TableContext): TableDefinition;
@@ -0,0 +1,43 @@
1
+ (function (factory) {
2
+ if (typeof module === "object" && typeof module.exports === "object") {
3
+ var v = factory(require, exports);
4
+ if (v !== undefined) module.exports = v;
5
+ }
6
+ else if (typeof define === "function" && define.amd) {
7
+ define(["require", "exports"], factory);
8
+ }
9
+ })(function (require, exports) {
10
+ "use strict";
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.tareas_proximas = void 0;
13
+ function tareas_proximas(context) {
14
+ var be = context.be;
15
+ var puedeEditar = context.user.rol === 'admin';
16
+ return {
17
+ name: 'tareas_proximas',
18
+ elementName: 'tarea',
19
+ editable: puedeEditar,
20
+ fields: [
21
+ { name: 'operativo', typeName: 'text', nullable: false },
22
+ { name: 'tarea', typeName: 'text', nullable: false },
23
+ { name: 'estado', typeName: 'text', nullable: false },
24
+ { name: 'tarea_destino', typeName: 'text', nullable: false },
25
+ { name: 'estado_destino', typeName: 'text', nullable: false },
26
+ { name: 'orden', typeName: 'integer', nullable: false },
27
+ { name: 'condicion', typeName: 'text', nullable: false },
28
+ { name: 'desasigna_en_tarea_destino', typeName: 'boolean' },
29
+ { name: 'nombre_procedure', typeName: 'text' },
30
+ ],
31
+ hiddenColumns: ['estados__permite_editar_encuesta', 'estado_dest__permite_editar_encuesta'],
32
+ primaryKey: ['operativo', 'tarea', 'estado', 'tarea_destino'],
33
+ foreignKeys: [
34
+ { references: 'tareas', fields: ['operativo', 'tarea'] },
35
+ { references: 'estados', fields: ['operativo', 'estado'] },
36
+ { references: 'tareas', fields: ['operativo', { source: 'tarea_destino', target: 'tarea' }], alias: 'tarea_dest' },
37
+ { references: 'estados', fields: ['operativo', { source: 'estado_destino', target: 'estado' }], alias: 'estado_dest' }
38
+ ],
39
+ };
40
+ }
41
+ exports.tareas_proximas = tareas_proximas;
42
+ });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGFyZWFzX3Byb3hpbWFzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NlcnZlci90YWJsZS10YXJlYXNfcHJveGltYXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0lBQUEsWUFBWSxDQUFDOzs7SUFJYixTQUFnQixlQUFlLENBQUMsT0FBb0I7UUFDaEQsSUFBSSxFQUFFLEdBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUNsQixJQUFJLFdBQVcsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBRyxPQUFPLENBQUM7UUFDN0MsT0FBTztZQUNILElBQUksRUFBQyxpQkFBaUI7WUFDdEIsV0FBVyxFQUFDLE9BQU87WUFDbkIsUUFBUSxFQUFDLFdBQVc7WUFDcEIsTUFBTSxFQUFDO2dCQUNILEVBQUMsSUFBSSxFQUFDLFdBQVcsRUFBb0IsUUFBUSxFQUFDLE1BQU0sRUFBTyxRQUFRLEVBQUUsS0FBSyxFQUFDO2dCQUMzRSxFQUFDLElBQUksRUFBQyxPQUFPLEVBQXdCLFFBQVEsRUFBQyxNQUFNLEVBQU8sUUFBUSxFQUFFLEtBQUssRUFBQztnQkFDM0UsRUFBQyxJQUFJLEVBQUMsUUFBUSxFQUF1QixRQUFRLEVBQUMsTUFBTSxFQUFPLFFBQVEsRUFBRSxLQUFLLEVBQUM7Z0JBQzNFLEVBQUMsSUFBSSxFQUFDLGVBQWUsRUFBZ0IsUUFBUSxFQUFDLE1BQU0sRUFBTyxRQUFRLEVBQUUsS0FBSyxFQUFDO2dCQUMzRSxFQUFDLElBQUksRUFBQyxnQkFBZ0IsRUFBZSxRQUFRLEVBQUMsTUFBTSxFQUFPLFFBQVEsRUFBRSxLQUFLLEVBQUM7Z0JBQzNFLEVBQUMsSUFBSSxFQUFDLE9BQU8sRUFBd0IsUUFBUSxFQUFDLFNBQVMsRUFBSSxRQUFRLEVBQUUsS0FBSyxFQUFDO2dCQUMzRSxFQUFDLElBQUksRUFBQyxXQUFXLEVBQW9CLFFBQVEsRUFBQyxNQUFNLEVBQU8sUUFBUSxFQUFFLEtBQUssRUFBQztnQkFDM0UsRUFBQyxJQUFJLEVBQUMsNEJBQTRCLEVBQUcsUUFBUSxFQUFDLFNBQVMsRUFBb0I7Z0JBQzNFLEVBQUMsSUFBSSxFQUFDLGtCQUFrQixFQUFhLFFBQVEsRUFBQyxNQUFNLEVBQXVCO2FBQzlFO1lBQ0QsYUFBYSxFQUFDLENBQUMsa0NBQWtDLEVBQUMsc0NBQXNDLENBQUM7WUFDekYsVUFBVSxFQUFDLENBQUMsV0FBVyxFQUFDLE9BQU8sRUFBRSxRQUFRLEVBQUUsZUFBZSxDQUFDO1lBQzNELFdBQVcsRUFBRTtnQkFDVCxFQUFDLFVBQVUsRUFBRSxRQUFRLEVBQUksTUFBTSxFQUFFLENBQUMsV0FBVyxFQUFDLE9BQU8sQ0FBQyxFQUFDO2dCQUN2RCxFQUFDLFVBQVUsRUFBRSxTQUFTLEVBQUcsTUFBTSxFQUFFLENBQUMsV0FBVyxFQUFDLFFBQVEsQ0FBQyxFQUFDO2dCQUN4RCxFQUFDLFVBQVUsRUFBRSxRQUFRLEVBQUksTUFBTSxFQUFFLENBQUMsV0FBVyxFQUFFLEVBQUMsTUFBTSxFQUFDLGVBQWUsRUFBRyxNQUFNLEVBQUMsT0FBTyxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUMsWUFBWSxFQUFFO2dCQUNoSCxFQUFDLFVBQVUsRUFBRSxTQUFTLEVBQUcsTUFBTSxFQUFFLENBQUMsV0FBVyxFQUFFLEVBQUMsTUFBTSxFQUFDLGdCQUFnQixFQUFFLE1BQU0sRUFBQyxRQUFRLEVBQUMsQ0FBQyxFQUFFLEtBQUssRUFBQyxhQUFhLEVBQUM7YUFDbkg7U0FDSixDQUFDO0lBQ04sQ0FBQztJQTNCRCwwQ0EyQkMiLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcclxuXHJcbmltcG9ydCB7VGFibGVEZWZpbml0aW9uLCBUYWJsZUNvbnRleHR9IGZyb20gXCIuL3R5cGVzLWRtZW5jdVwiO1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIHRhcmVhc19wcm94aW1hcyhjb250ZXh0OlRhYmxlQ29udGV4dCk6VGFibGVEZWZpbml0aW9uIHtcclxuICAgIHZhciBiZT1jb250ZXh0LmJlO1xyXG4gICAgdmFyIHB1ZWRlRWRpdGFyID0gY29udGV4dC51c2VyLnJvbD09PSdhZG1pbic7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAgIG5hbWU6J3RhcmVhc19wcm94aW1hcycsXHJcbiAgICAgICAgZWxlbWVudE5hbWU6J3RhcmVhJyxcclxuICAgICAgICBlZGl0YWJsZTpwdWVkZUVkaXRhcixcclxuICAgICAgICBmaWVsZHM6W1xyXG4gICAgICAgICAgICB7bmFtZTonb3BlcmF0aXZvJyAgICAgICAgICAgICAgICAgICwgdHlwZU5hbWU6J3RleHQnICAgICwgIG51bGxhYmxlOiBmYWxzZX0sXHJcbiAgICAgICAgICAgIHtuYW1lOid0YXJlYScgICAgICAgICAgICAgICAgICAgICAgLCB0eXBlTmFtZTondGV4dCcgICAgLCAgbnVsbGFibGU6IGZhbHNlfSxcclxuICAgICAgICAgICAge25hbWU6J2VzdGFkbycgICAgICAgICAgICAgICAgICAgICAsIHR5cGVOYW1lOid0ZXh0JyAgICAsICBudWxsYWJsZTogZmFsc2V9LFxyXG4gICAgICAgICAgICB7bmFtZTondGFyZWFfZGVzdGlubycgICAgICAgICAgICAgICwgdHlwZU5hbWU6J3RleHQnICAgICwgIG51bGxhYmxlOiBmYWxzZX0sXHJcbiAgICAgICAgICAgIHtuYW1lOidlc3RhZG9fZGVzdGlubycgICAgICAgICAgICAgLCB0eXBlTmFtZTondGV4dCcgICAgLCAgbnVsbGFibGU6IGZhbHNlfSxcclxuICAgICAgICAgICAge25hbWU6J29yZGVuJyAgICAgICAgICAgICAgICAgICAgICAsIHR5cGVOYW1lOidpbnRlZ2VyJyAsICBudWxsYWJsZTogZmFsc2V9LFxyXG4gICAgICAgICAgICB7bmFtZTonY29uZGljaW9uJyAgICAgICAgICAgICAgICAgICwgdHlwZU5hbWU6J3RleHQnICAgICwgIG51bGxhYmxlOiBmYWxzZX0sXHJcbiAgICAgICAgICAgIHtuYW1lOidkZXNhc2lnbmFfZW5fdGFyZWFfZGVzdGlubycgLCB0eXBlTmFtZTonYm9vbGVhbicgICAgICAgICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAge25hbWU6J25vbWJyZV9wcm9jZWR1cmUnICAgICAgICAgICAsIHR5cGVOYW1lOid0ZXh0JyAgICAgICAgICAgICAgICAgICAgICB9LFxyXG4gICAgICAgIF0sXHJcbiAgICAgICAgaGlkZGVuQ29sdW1uczpbJ2VzdGFkb3NfX3Blcm1pdGVfZWRpdGFyX2VuY3Vlc3RhJywnZXN0YWRvX2Rlc3RfX3Blcm1pdGVfZWRpdGFyX2VuY3Vlc3RhJ10sXHJcbiAgICAgICAgcHJpbWFyeUtleTpbJ29wZXJhdGl2bycsJ3RhcmVhJywgJ2VzdGFkbycsICd0YXJlYV9kZXN0aW5vJ10sXHJcbiAgICAgICAgZm9yZWlnbktleXM6IFtcclxuICAgICAgICAgICAge3JlZmVyZW5jZXM6ICd0YXJlYXMnICAsIGZpZWxkczogWydvcGVyYXRpdm8nLCd0YXJlYSddfSxcclxuICAgICAgICAgICAge3JlZmVyZW5jZXM6ICdlc3RhZG9zJyAsIGZpZWxkczogWydvcGVyYXRpdm8nLCdlc3RhZG8nXX0sXHJcbiAgICAgICAgICAgIHtyZWZlcmVuY2VzOiAndGFyZWFzJyAgLCBmaWVsZHM6IFsnb3BlcmF0aXZvJywge3NvdXJjZTondGFyZWFfZGVzdGlubycgLCB0YXJnZXQ6J3RhcmVhJyB9XSwgYWxpYXM6J3RhcmVhX2Rlc3QnIH0sXHJcbiAgICAgICAgICAgIHtyZWZlcmVuY2VzOiAnZXN0YWRvcycgLCBmaWVsZHM6IFsnb3BlcmF0aXZvJywge3NvdXJjZTonZXN0YWRvX2Rlc3Rpbm8nLCB0YXJnZXQ6J2VzdGFkbyd9XSwgYWxpYXM6J2VzdGFkb19kZXN0J31cclxuICAgICAgICBdLFxyXG4gICAgfTtcclxufVxyXG5cclxuIl19
@@ -0,0 +1,23 @@
1
+ --set role dmencu_owner;
2
+ --set search_path=base;
3
+ DROP FUNCTION if exists desverificar_tarea_trg();
4
+ CREATE OR REPLACE FUNCTION desverificar_tarea_trg()
5
+ RETURNS trigger
6
+ LANGUAGE 'plpgsql'
7
+ AS $BODY$
8
+ begin
9
+ if new.verificado is null then
10
+ update tem
11
+ set tarea_proxima = null
12
+ where operativo = new.operativo and enc = new.enc;
13
+ end if;
14
+ return new;
15
+ end;
16
+ $BODY$;
17
+
18
+ DROP TRIGGER IF EXISTS desverificar_tarea_trg ON tareas_tem;
19
+ CREATE TRIGGER desverificar_tarea_trg
20
+ AFTER UPDATE OF verificado
21
+ ON tareas_tem
22
+ FOR EACH ROW
23
+ EXECUTE PROCEDURE desverificar_tarea_trg();
@@ -0,0 +1,34 @@
1
+ --set role to ggs2022_owner;
2
+ --set search_path=base;
3
+ CREATE OR REPLACE FUNCTION tarea_cumple_condicion(p_operativo text, p_tarea text, p_estado text, p_enc text, p_condicion text)
4
+ RETURNS boolean AS
5
+ $BODY$
6
+ DECLARE
7
+ v_sent text;
8
+ v_cond text;
9
+ v_salida integer;
10
+ BEGIN
11
+ v_cond=p_condicion;
12
+ v_sent=' select 1
13
+ from base.tareas_tem t
14
+ inner join base.tareas_proximas tp using (operativo, tarea, estado)
15
+ inner join tem te using (operativo,enc)
16
+ left join tokens tok on t.cargado_dm=tok.token
17
+ left join viviendas v on (te.operativo = v.operativo and te.enc = v.vivienda)
18
+ left join no_rea nr on (te.norea::text = nr.no_rea)
19
+ where t.operativo='||quote_literal(p_operativo)||
20
+ ' and t.tarea='||quote_literal(p_tarea)||
21
+ ' and t.estado='||quote_literal(p_estado)||
22
+ ' and t.enc='||quote_literal(p_enc)||
23
+ ' and '||v_cond||';';
24
+ --raise notice 'esto %',vsent;
25
+ execute v_sent into v_salida;
26
+ IF v_salida=1 THEN
27
+ return true;
28
+ ELSE
29
+ return false;
30
+ END IF;
31
+
32
+ END;
33
+ $BODY$
34
+ LANGUAGE plpgsql VOLATILE;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "dmencu",
3
3
  "description": "DM Encu - Encuestas en dispositivo móvil",
4
- "version": "0.7.30",
4
+ "version": "0.8.0",
5
5
  "author": "Codenautas <codenautas@googlegroups.com>",
6
6
  "license": "MIT",
7
7
  "main": "dist/server/server/app-dmencu.js",