dmencu 0.3.42 → 0.3.43
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.
- package/dist/client/client/client.js +6 -6
- package/dist/client/unlogged/render-formulario.tsx +1 -2
- package/dist/server/server/app-dmencu.d.ts +24 -8
- package/dist/server/server/app-dmencu.js +148 -125
- package/dist/server/server/table-areas.d.ts +2 -0
- package/dist/server/server/table-areas.js +47 -55
- package/dist/server/server/table-encuestadores.d.ts +8 -1
- package/dist/server/server/table-encuestadores.js +54 -7
- package/dist/server/server/table-personal.d.ts +1 -1
- package/dist/server/server/table-personal.js +1 -1
- package/dist/server/server/table-tareas.d.ts +1 -1
- package/dist/server/server/table-tareas.js +2 -2
- package/dist/server/server/table-tareas_areas.d.ts +5 -1
- package/dist/server/server/table-tareas_areas.js +37 -13
- package/dist/server/server/table-tareas_tem.js +12 -21
- package/dist/server/server/table-tareas_tem_asignables.d.ts +3 -3
- package/dist/server/server/table-tareas_tem_asignables.js +56 -56
- package/dist/server/server/table-tem.d.ts +2 -2
- package/dist/server/server/table-tem.js +1 -1
- package/dist/server/server/table-tem_asignacion.js +2 -2
- package/dist/server/server/types-dmencu.d.ts +39 -18
- package/dist/server/server/types-dmencu.js +1 -1
- package/dist/unlogged/unlogged/render-formulario.js +1 -2
- package/dist/unlogged/unlogged/render-formulario.tsx +1 -2
- package/install/actualizar-2023-05-14.sql +38 -0
- package/install/asignar_desasignar_tareas_tem_trg.sql +38 -38
- package/install/sincro_tareas_areas_tareas_tem_trg.sql +27 -28
- package/install/validar_tareas_tem_trg.sql +70 -70
- package/package.json +1 -1
|
@@ -1,3 +1,5 @@
|
|
|
1
1
|
/// <reference types="backend-plus" />
|
|
2
2
|
import { TableDefinition, TableContext } from "./types-dmencu";
|
|
3
|
+
export declare const cuentasSql: (be: any, filter: string) => string;
|
|
4
|
+
export declare const cuentasFields: (be: any) => any[];
|
|
3
5
|
export declare function areas(context: TableContext): TableDefinition;
|
|
@@ -9,7 +9,46 @@
|
|
|
9
9
|
})(function (require, exports) {
|
|
10
10
|
"use strict";
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.areas = void 0;
|
|
12
|
+
exports.areas = exports.cuentasFields = exports.cuentasSql = void 0;
|
|
13
|
+
const cuentasSql = (be, filter) => `
|
|
14
|
+
select
|
|
15
|
+
bool_or( ttcargado_dm is not null ) as cargado ,
|
|
16
|
+
--count( cargado_dm ) as cargadas,
|
|
17
|
+
sum ( case when tem.rea= 1 then 1 else null end ) as reas,
|
|
18
|
+
count(*) filter ( where tem.resumen_estado='no rea') as no_reas,
|
|
19
|
+
count(*) filter ( where tem.resumen_estado in ('incompleto', 'con problemas') ) as incompletas,
|
|
20
|
+
count(*) filter ( where tem.resumen_estado in ('vacio' ) ) as vacias,
|
|
21
|
+
count(*) filter ( where thabilitada is not true ) as inhabilitadas,
|
|
22
|
+
--sum(case when cluster <>4 then null when confirmada is true then 1 else 0 end) as confirmadas,
|
|
23
|
+
--sum(case when cluster <>4 then null when confirmada is null then 1 else 0 end) as pend_conf,
|
|
24
|
+
string_agg(distinct clase,', ' order by clase desc) as clases,
|
|
25
|
+
string_agg(distinct nrocomuna::text,'0' order by nrocomuna::text)::bigint as comuna
|
|
26
|
+
, string_agg(distinct cluster::text,', ' order by cluster::text desc) as clusters
|
|
27
|
+
${be.caches.tableContent.no_rea_groups.map(x => `, sum(CASE WHEN gru_no_rea=${be.db.quoteLiteral(x.grupo)} THEN 1 ELSE NULL END) as ${be.db.quoteIdent(x.grupo.replace(/ /g, '_'))}`).join('')}
|
|
28
|
+
from ( select operativo, enc, cluster, nrocomuna, clase,
|
|
29
|
+
json_encuesta, t.resumen_estado,
|
|
30
|
+
t.rea, t.norea, area, dominio, zona,
|
|
31
|
+
json_backup, grupo as gru_no_rea
|
|
32
|
+
, bool_or(t.habilitada) thabilitada, string_agg(tt.cargado_dm,'-') ttcargado_dm
|
|
33
|
+
from tem t left join tareas_tem tt using(operativo,enc)
|
|
34
|
+
left join no_rea y on y.no_rea::integer=t.norea
|
|
35
|
+
where ${filter}
|
|
36
|
+
group by 1,2,3,4,5,6,7,8,9,10,11,12,13,14
|
|
37
|
+
) tem
|
|
38
|
+
`;
|
|
39
|
+
exports.cuentasSql = cuentasSql;
|
|
40
|
+
const cuentasFields = (be) => [
|
|
41
|
+
{ name: 'clases', typeName: 'text', editable: false, inTable: false },
|
|
42
|
+
{ name: 'cargado', typeName: 'boolean', editable: false, inTable: false },
|
|
43
|
+
{ name: 'reas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
44
|
+
{ name: 'no_reas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
45
|
+
{ name: 'incompletas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
46
|
+
{ name: 'vacias', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
47
|
+
{ name: 'inhabilitadas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
48
|
+
{ name: 'comuna', typeName: 'bigint', title: 'comuna', inTable: false },
|
|
49
|
+
...be.caches.tableContent.no_rea_groups.map(x => ({ name: x.grupo.replace(/ /g, '_'), typeName: 'integer', editable: false }))
|
|
50
|
+
];
|
|
51
|
+
exports.cuentasFields = cuentasFields;
|
|
13
52
|
function areas(context) {
|
|
14
53
|
var _a, _b;
|
|
15
54
|
var be = context.be;
|
|
@@ -22,56 +61,33 @@
|
|
|
22
61
|
'incompletas_bkp', 'vacias_bkp', 'inhabilitadas_bkp'
|
|
23
62
|
],
|
|
24
63
|
fields: [
|
|
25
|
-
{
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
typeName: "text",
|
|
29
|
-
nullable: false
|
|
30
|
-
},
|
|
31
|
-
{
|
|
32
|
-
name: 'area',
|
|
33
|
-
typeName: 'integer',
|
|
34
|
-
nullable: false,
|
|
35
|
-
editable: false
|
|
36
|
-
},
|
|
37
|
-
{ name: 'clusters', typeName: 'text' },
|
|
64
|
+
{ name: "operativo", typeName: "text", nullable: false, editable: false },
|
|
65
|
+
{ name: 'area', typeName: 'integer', nullable: false, editable: false },
|
|
66
|
+
{ name: 'clusters', typeName: 'text', visible: false },
|
|
38
67
|
{ name: 'recepcionista', typeName: 'text', references: 'recepcionistas' },
|
|
39
68
|
{ name: 'encuestador', typeName: 'text' },
|
|
40
69
|
//{name:'recuperador' , typeName:'text' },
|
|
41
70
|
//{name:'supervisor' , typeName:'text' },
|
|
42
71
|
{ name: 'observaciones_hdr', typeName: 'text' },
|
|
43
|
-
{ name: 'clases', typeName: 'text', editable: false, inTable: false },
|
|
44
|
-
{ name: 'cargado', typeName: 'boolean', editable: false, inTable: false },
|
|
45
|
-
{ name: 'reas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
46
|
-
{ name: 'no_reas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
47
|
-
{ name: 'incompletas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
48
|
-
{ name: 'vacias', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
49
|
-
{ name: 'inhabilitadas', typeName: 'integer', editable: false, aggregate: 'sum', inTable: false },
|
|
50
72
|
{ name: 'verificado_rec', typeName: 'text', aggregate: 'count' },
|
|
51
73
|
//{name:'confirmadas' , typeName:'integer' , editable:false, aggregate:'sum'},
|
|
52
74
|
//{name:'pend_conf' , typeName:'integer' , editable:false, aggregate:'sum', description:'pendientes de confirmación'},
|
|
53
75
|
{ name: 'obs_recepcionista', typeName: 'text' },
|
|
54
|
-
|
|
76
|
+
...(0, exports.cuentasFields)(be),
|
|
55
77
|
{ name: 'cargadas_bkp', typeName: 'integer', editable: false },
|
|
56
78
|
{ name: 'reas_bkp', typeName: 'integer', editable: false },
|
|
57
79
|
{ name: 'no_reas_bkp', typeName: 'integer', editable: false },
|
|
58
80
|
{ name: 'incompletas_bkp', typeName: 'integer', editable: false },
|
|
59
81
|
{ name: 'vacias_bkp', typeName: 'integer', editable: false },
|
|
60
82
|
{ name: 'inhabilitadas_bkp', typeName: 'integer', editable: false },
|
|
61
|
-
...be.caches.tableContent.no_rea_groups.map(x => ({ name: x.grupo.replace(/ /g, '_'), typeName: 'integer', editable: false }))
|
|
62
83
|
],
|
|
63
84
|
primaryKey: ["operativo", 'area'],
|
|
64
85
|
foreignKeys: [
|
|
65
86
|
{ references: 'operativos', fields: ['operativo'] },
|
|
66
|
-
//{references:'operaciones', fields:[{source:'operacion_area', target:'operacion'}]},
|
|
67
|
-
//{references:'usuarios', fields:[{source:'encuestador' , target:'idper'}], alias:'per_enc', displayFields:[]},
|
|
68
87
|
{ references: 'usuarios', fields: [{ source: 'recepcionista', target: 'idper' }], alias: 'per_recep', displayFields: [] },
|
|
69
88
|
],
|
|
70
89
|
softForeignKeys: [
|
|
71
|
-
//{references:'operativos', fields:['operativo']},
|
|
72
90
|
{ references: 'encuestadores', fields: [{ source: 'encuestador', target: 'persona' }], alias: 'per_encu' },
|
|
73
|
-
//{references:'recuperadores', fields:[{source:'recuperador', target:'persona'}], alias:'per_recu'},
|
|
74
|
-
//{references:'supervisores', fields:[{source:'supervisor', target:'persona'}], alias:'per_supe'},
|
|
75
91
|
],
|
|
76
92
|
detailTables: [
|
|
77
93
|
{ table: 'tem_asignacion', fields: ['operativo', 'area'], abr: 'A', refreshParent: true, label: 'asignables' },
|
|
@@ -85,32 +101,8 @@
|
|
|
85
101
|
--a.operacion_area, a.fecha,
|
|
86
102
|
, a.cargadas_bkp, a.reas_bkp, a.no_reas_bkp, a.incompletas_bkp, a.vacias_bkp, a.inhabilitadas_bkp
|
|
87
103
|
, t.*
|
|
88
|
-
from areas a left join tareas_areas ta on ta.tarea='encu' and ta.area=a.area and ta.operativo=a.operativo, lateral(
|
|
89
|
-
|
|
90
|
-
bool_or( ttcargado_dm is not null ) as cargado ,
|
|
91
|
-
--count( cargado_dm ) as cargadas,
|
|
92
|
-
sum ( case when tem.rea= 1 then 1 else null end ) as reas,
|
|
93
|
-
count(*) filter ( where tem.resumen_estado='no rea') as no_reas,
|
|
94
|
-
count(*) filter ( where tem.resumen_estado in ('incompleto', 'con problemas') ) as incompletas,
|
|
95
|
-
count(*) filter ( where tem.resumen_estado in ('vacio' ) ) as vacias,
|
|
96
|
-
count(*) filter ( where thabilitada is not true ) as inhabilitadas,
|
|
97
|
-
--sum(case when cluster <>4 then null when confirmada is true then 1 else 0 end) as confirmadas,
|
|
98
|
-
--sum(case when cluster <>4 then null when confirmada is null then 1 else 0 end) as pend_conf,
|
|
99
|
-
string_agg(distinct clase,', ' order by clase desc) as clases,
|
|
100
|
-
string_agg(distinct nrocomuna::text,'0' order by nrocomuna::text)::bigint as comuna
|
|
101
|
-
, string_agg(distinct cluster::text,', ' order by cluster::text desc) as clusters
|
|
102
|
-
${be.caches.tableContent.no_rea_groups.map(x => `, sum(CASE WHEN gru_no_rea=${be.db.quoteLiteral(x.grupo)} THEN 1 ELSE NULL END) as ${be.db.quoteIdent(x.grupo.replace(/ /g, '_'))}`).join('')}
|
|
103
|
-
from ( select operativo, enc, cluster, nrocomuna, clase,
|
|
104
|
-
json_encuesta, t.resumen_estado,
|
|
105
|
-
encuestador, t.rea, t.norea, area, dominio, zona,
|
|
106
|
-
json_backup, grupo as gru_no_rea
|
|
107
|
-
, bool_or(t.habilitada) thabilitada, string_agg(tt.cargado_dm,'-') ttcargado_dm
|
|
108
|
-
from tem t left join tareas_tem tt using(operativo,enc)
|
|
109
|
-
left join no_rea y on y.no_rea::integer=t.norea
|
|
110
|
-
where t.area=a.area /*and tt.tarea='encu'*/
|
|
111
|
-
group by 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15
|
|
112
|
-
) tem
|
|
113
|
-
|
|
104
|
+
from areas a left join tareas_areas ta on ta.tarea='encu' and ta.area=a.area and ta.operativo=a.operativo, lateral (
|
|
105
|
+
${(0, exports.cuentasSql)(be, `t.area=a.area /*and tt.tarea='encu'*/`)}
|
|
114
106
|
) t
|
|
115
107
|
)`
|
|
116
108
|
}
|
|
@@ -118,4 +110,4 @@
|
|
|
118
110
|
}
|
|
119
111
|
exports.areas = areas;
|
|
120
112
|
});
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-areas.js","sourceRoot":"","sources":["../../../src/server/table-areas.ts"],"names":[],"mappings":";;;;;;;;;IAAA,YAAY,CAAC;;;IAIb,SAAgB,KAAK,CAAC,OAAoB;;QACtC,IAAI,EAAE,GAAC,OAAO,CAAC,EAAE,CAAC;QAClB,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,OAAO;YACH,IAAI,EAAC,OAAO;YACZ,WAAW,EAAC,MAAM;YAClB,QAAQ,EAAC,WAAW;YACpB,aAAa,EAAC,CAAC,UAAU,EAAE,QAAQ,EAAC,cAAc,EAAE,UAAU,EAAE,aAAa;gBACvE,iBAAiB,EAAE,YAAY,EAAE,mBAAmB;aACzD;YACD,MAAM,EAAC;gBACH;oBACI,IAAI,EAAE,WAAW;oBACjB,QAAQ,EAAE,KAAK;oBACf,QAAQ,EAAE,MAAM;oBAChB,QAAQ,EAAE,KAAK;iBAClB;gBACD;oBACI,IAAI,EAAE,MAAM;oBACZ,QAAQ,EAAE,SAAS;oBACnB,QAAQ,EAAE,KAAK;oBACf,QAAQ,EAAE,KAAK;iBAClB;gBACD,EAAC,IAAI,EAAC,UAAU,EAAkB,QAAQ,EAAC,MAAM,EAAM;gBACvD,EAAC,IAAI,EAAC,eAAe,EAAa,QAAQ,EAAC,MAAM,EAAE,UAAU,EAAC,gBAAgB,EAAC;gBAC/E,EAAC,IAAI,EAAC,aAAa,EAAe,QAAQ,EAAC,MAAM,EAAqB;gBACtE,yEAAyE;gBACzE,yEAAyE;gBACzE,EAAC,IAAI,EAAC,mBAAmB,EAAS,QAAQ,EAAC,MAAM,EAAuB;gBACxE,EAAC,IAAI,EAAC,QAAQ,EAAoB,QAAQ,EAAC,MAAM,EAAM,QAAQ,EAAC,KAAK,EAAI,OAAO,EAAC,KAAK,EAAC;gBACvF,EAAC,IAAI,EAAC,SAAS,EAAmB,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAI,OAAO,EAAC,KAAK,EAAC;gBACvF,EAAC,IAAI,EAAC,MAAM,EAAsB,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAI,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,KAAK,EAAE;gBACzG,EAAC,IAAI,EAAC,SAAS,EAAmB,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAI,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,KAAK,EAAE;gBACzG,EAAC,IAAI,EAAC,aAAa,EAAe,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAI,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,KAAK,EAAE;gBACzG,EAAC,IAAI,EAAC,QAAQ,EAAoB,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAI,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,KAAK,EAAE;gBACzG,EAAC,IAAI,EAAC,eAAe,EAAa,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAI,SAAS,EAAC,KAAK,EAAE,OAAO,EAAC,KAAK,EAAE;gBACzG,EAAC,IAAI,EAAC,gBAAgB,EAAY,QAAQ,EAAC,MAAM,EAAwB,SAAS,EAAC,OAAO,EAAE;gBAC5F,0FAA0F;gBAC1F,oIAAoI;gBACpI,EAAC,IAAI,EAAC,mBAAmB,EAAS,QAAQ,EAAC,MAAM,EAAuB;gBACxE,EAAC,IAAI,EAAC,QAAQ,EAAoB,QAAQ,EAAC,QAAQ,EAAI,KAAK,EAAC,QAAQ,EAAI,OAAO,EAAC,KAAK,EAAC;gBACvF,EAAC,IAAI,EAAC,cAAc,EAAc,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAG;gBACxE,EAAC,IAAI,EAAC,UAAU,EAAkB,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAG;gBACxE,EAAC,IAAI,EAAC,aAAa,EAAe,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAG;gBACxE,EAAC,IAAI,EAAC,iBAAiB,EAAW,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAG;gBACxE,EAAC,IAAI,EAAC,YAAY,EAAgB,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAG;gBACxE,EAAC,IAAI,EAAC,mBAAmB,EAAS,QAAQ,EAAC,SAAS,EAAG,QAAQ,EAAC,KAAK,EAAG;gBACxE,GAAG,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAAA,CAC3C,EAAC,IAAI,EAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAC,GAAG,CAAC,EAAE,QAAQ,EAAC,SAAS,EAAE,QAAQ,EAAC,KAAK,EAAC,CACvE,CAAC;aACL;YACD,UAAU,EAAC,CAAC,WAAW,EAAC,MAAM,CAAC;YAC/B,WAAW,EAAC;gBACR,EAAC,UAAU,EAAC,YAAY,EAAE,MAAM,EAAC,CAAC,WAAW,CAAC,EAAC;gBAC/C,qFAAqF;gBACrF,kHAAkH;gBAClH,EAAC,UAAU,EAAC,UAAU,EAAE,MAAM,EAAC,CAAC,EAAC,MAAM,EAAC,eAAe,EAAE,MAAM,EAAC,OAAO,EAAC,CAAC,EAAE,KAAK,EAAC,WAAW,EAAE,aAAa,EAAC,EAAE,EAAC;aAClH;YACD,eAAe,EAAC;gBACZ,kDAAkD;gBAClD,EAAC,UAAU,EAAC,eAAe,EAAE,MAAM,EAAC,CAAC,EAAC,MAAM,EAAC,aAAa,EAAE,MAAM,EAAC,SAAS,EAAC,CAAC,EAAE,KAAK,EAAC,UAAU,EAAC;gBACjG,oGAAoG;gBACpG,kGAAkG;aACrG;YACD,YAAY,EAAC;gBACT,EAAC,KAAK,EAAC,gBAAgB,EAAG,MAAM,EAAC,CAAC,WAAW,EAAC,MAAM,CAAC,EAAE,GAAG,EAAC,GAAG,EAAE,aAAa,EAAC,IAAI,EAAE,KAAK,EAAC,YAAY,EAAC;gBACvG,EAAC,KAAK,EAAC,sBAAsB,EAAI,MAAM,EAAC,CAAC,WAAW,EAAE,MAAM,CAAC,EAAE,GAAG,EAAC,GAAG,EAAE,aAAa,EAAC,IAAI,EAAE,KAAK,EAAC,WAAW,EAAC;aACjH;YACD,GAAG,EAAC;gBACA,OAAO,EAAC,IAAI;gBACZ,IAAI,EAAC;;;;;;;;;;;;;;;;;;;;0BAoBS,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAA,EAAE,CAC7C,8BAA8B,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,6BAA6B,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAC,GAAG,CAAC,CAAC,EAAE,CACnI,CAAC,IAAI,CAAC,EAAE,CAAC;;;;;;;;;;;;;cAapB;aACL;SAEJ,CAAC;IACN,CAAC;IA7GD,sBA6GC","sourcesContent":["\"use strict\";\r\n\r\nimport {TableDefinition, TableContext} from \"./types-dmencu\";\r\n\r\nexport function areas(context:TableContext):TableDefinition {\r\n    var be=context.be;\r\n    var puedeEditar = context.forDump || context.puede?.campo?.administrar||context.user.rol==='recepcionista';\r\n    return {\r\n        name:'areas',\r\n        elementName:'area',\r\n        editable:puedeEditar,\r\n        hiddenColumns:['clusters', 'clases','cargadas_bkp', 'reas_bkp', 'no_reas_bkp'  \r\n            , 'incompletas_bkp', 'vacias_bkp', 'inhabilitadas_bkp'\r\n        ],\r\n        fields:[\r\n            {\r\n                name: \"operativo\",\r\n                editable: false,\r\n                typeName: \"text\",\r\n                nullable: false\r\n            },\r\n            { \r\n                name: 'area',\r\n                typeName: 'integer',\r\n                nullable: false,\r\n                editable: false\r\n            },\r\n            {name:'clusters'                , typeName:'text'     },\r\n            {name:'recepcionista'           , typeName:'text', references:'recepcionistas'},\r\n            {name:'encuestador'             , typeName:'text'                    },\r\n            //{name:'recuperador'             , typeName:'text'                    },\r\n            //{name:'supervisor'              , typeName:'text'                    },\r\n            {name:'observaciones_hdr'       , typeName:'text'                      },\r\n            {name:'clases'                  , typeName:'text'    , editable:false  , inTable:false},\r\n            {name:'cargado'                 , typeName:'boolean' , editable:false  , inTable:false},\r\n            {name:'reas'                    , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n            {name:'no_reas'                 , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n            {name:'incompletas'             , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n            {name:'vacias'                  , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n            {name:'inhabilitadas'           , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n            {name:'verificado_rec'          , typeName:'text'                      , aggregate:'count' },\r\n            //{name:'confirmadas'             , typeName:'integer' , editable:false, aggregate:'sum'},\r\n            //{name:'pend_conf'               , typeName:'integer' , editable:false, aggregate:'sum', description:'pendientes de confirmación'},\r\n            {name:'obs_recepcionista'       , typeName:'text'                      },\r\n            {name:'comuna'                  , typeName:'bigint'  , title:'comuna'  , inTable:false},\r\n            {name:'cargadas_bkp'            , typeName:'integer' , editable:false  },\r\n            {name:'reas_bkp'                , typeName:'integer' , editable:false  },\r\n            {name:'no_reas_bkp'             , typeName:'integer' , editable:false  },\r\n            {name:'incompletas_bkp'         , typeName:'integer' , editable:false  },\r\n            {name:'vacias_bkp'              , typeName:'integer' , editable:false  },\r\n            {name:'inhabilitadas_bkp'       , typeName:'integer' , editable:false  },\r\n            ...be.caches.tableContent.no_rea_groups.map(x=>(\r\n                {name:x.grupo.replace(/ /g,'_'), typeName:'integer', editable:false}\r\n            ))\r\n        ],\r\n        primaryKey:[\"operativo\",'area'],\r\n        foreignKeys:[\r\n            {references:'operativos', fields:['operativo']},\r\n            //{references:'operaciones', fields:[{source:'operacion_area', target:'operacion'}]},\r\n            //{references:'usuarios', fields:[{source:'encuestador'    , target:'idper'}], alias:'per_enc', displayFields:[]},\r\n            {references:'usuarios', fields:[{source:'recepcionista', target:'idper'}], alias:'per_recep', displayFields:[]},\r\n        ],\r\n        softForeignKeys:[\r\n            //{references:'operativos', fields:['operativo']},\r\n            {references:'encuestadores', fields:[{source:'encuestador', target:'persona'}], alias:'per_encu'},\r\n            //{references:'recuperadores', fields:[{source:'recuperador', target:'persona'}], alias:'per_recu'},\r\n            //{references:'supervisores', fields:[{source:'supervisor', target:'persona'}], alias:'per_supe'},\r\n        ],\r\n        detailTables:[\r\n            {table:'tem_asignacion' , fields:['operativo','area'], abr:'A', refreshParent:true, label:'asignables'},\r\n            {table:`tareas_tem_recepcion`  , fields:['operativo', 'area'], abr:'R', refreshParent:true, label:'recepcion'},\r\n        ],\r\n        sql:{\r\n            isTable:true,\r\n            from:` \r\n            (select a.operativo, a.area, a.recepcionista, ta.asignado encuestador\r\n                ,  a.observaciones_hdr, a.verificado_rec, a.obs_recepcionista\r\n                  --a.operacion_area, a.fecha,\r\n                , a.cargadas_bkp, a.reas_bkp, a.no_reas_bkp, a.incompletas_bkp, a.vacias_bkp, a.inhabilitadas_bkp\r\n                , t.*\r\n                from areas a left join tareas_areas ta on ta.tarea='encu' and ta.area=a.area and ta.operativo=a.operativo, lateral(\r\n                    select \r\n                        bool_or( ttcargado_dm is not null )       as cargado , \r\n                        --count( cargado_dm )                     as cargadas,\r\n                        sum ( case when tem.rea= 1 then 1 else null end )                              as reas,\r\n                        count(*) filter ( where tem.resumen_estado='no rea')       as no_reas,\r\n                        count(*) filter ( where tem.resumen_estado in ('incompleto', 'con problemas') ) as incompletas, \r\n                        count(*) filter ( where tem.resumen_estado in ('vacio' ) ) as vacias,\r\n                        count(*) filter ( where thabilitada is not true )    as inhabilitadas,\r\n                        --sum(case when cluster <>4 then null when confirmada is true then 1 else 0 end) as confirmadas,\r\n                        --sum(case when cluster <>4 then null when confirmada is null then 1 else 0 end) as pend_conf,\r\n                        string_agg(distinct clase,', ' order by clase desc) as clases,\r\n                        string_agg(distinct nrocomuna::text,'0' order by nrocomuna::text)::bigint as comuna\r\n                        , string_agg(distinct cluster::text,', ' order by cluster::text desc) as clusters\r\n                        ${be.caches.tableContent.no_rea_groups.map(x=>\r\n                        \t`, sum(CASE WHEN gru_no_rea=${be.db.quoteLiteral(x.grupo)} THEN 1 ELSE NULL END) as ${be.db.quoteIdent(x.grupo.replace(/ /g,'_'))}`\r\n                        ).join('')}\r\n                        from ( select operativo, enc, cluster, nrocomuna, clase, \r\n                                    json_encuesta, t.resumen_estado,  \r\n                                    encuestador, t.rea, t.norea, area, dominio, zona,\r\n                                    json_backup, grupo as gru_no_rea\r\n                                    , bool_or(t.habilitada) thabilitada, string_agg(tt.cargado_dm,'-') ttcargado_dm                             \r\n                                from tem t left join tareas_tem tt using(operativo,enc) \r\n                                    left join no_rea y on y.no_rea::integer=t.norea\r\n                                where t.area=a.area /*and tt.tarea='encu'*/    \r\n                                group by  1,2,3,4,5,6,7,8,9,10,11,12,13,14,15  \r\n                        ) tem\r\n                                \r\n                ) t\r\n            )`\r\n        }\r\n\r\n    };\r\n}\r\n\r\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-areas.js","sourceRoot":"","sources":["../../../src/server/table-areas.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport {TableDefinition, TableContext} from \"./types-dmencu\";\r\n\r\nexport const cuentasSql = (be:any, filter:string) => `\r\nselect \r\n    bool_or( ttcargado_dm is not null )       as cargado , \r\n    --count( cargado_dm )                     as cargadas,\r\n    sum ( case when tem.rea= 1 then 1 else null end )                              as reas,\r\n    count(*) filter ( where tem.resumen_estado='no rea')       as no_reas,\r\n    count(*) filter ( where tem.resumen_estado in ('incompleto', 'con problemas') ) as incompletas, \r\n    count(*) filter ( where tem.resumen_estado in ('vacio' ) ) as vacias,\r\n    count(*) filter ( where thabilitada is not true )    as inhabilitadas,\r\n    --sum(case when cluster <>4 then null when confirmada is true then 1 else 0 end) as confirmadas,\r\n    --sum(case when cluster <>4 then null when confirmada is null then 1 else 0 end) as pend_conf,\r\n    string_agg(distinct clase,', ' order by clase desc) as clases,\r\n    string_agg(distinct nrocomuna::text,'0' order by nrocomuna::text)::bigint as comuna\r\n    , string_agg(distinct cluster::text,', ' order by cluster::text desc) as clusters\r\n    ${be.caches.tableContent.no_rea_groups.map(x=>\r\n        `, sum(CASE WHEN gru_no_rea=${be.db.quoteLiteral(x.grupo)} THEN 1 ELSE NULL END) as ${be.db.quoteIdent(x.grupo.replace(/ /g,'_'))}`\r\n    ).join('')}\r\nfrom ( select operativo, enc, cluster, nrocomuna, clase, \r\n            json_encuesta, t.resumen_estado,  \r\n            t.rea, t.norea, area, dominio, zona,\r\n            json_backup, grupo as gru_no_rea\r\n            , bool_or(t.habilitada) thabilitada, string_agg(tt.cargado_dm,'-') ttcargado_dm                             \r\n        from tem t left join tareas_tem tt using(operativo,enc) \r\n            left join no_rea y on y.no_rea::integer=t.norea\r\n        where ${filter}    \r\n        group by  1,2,3,4,5,6,7,8,9,10,11,12,13,14\r\n) tem\r\n`;\r\n\r\nexport const cuentasFields = (be:any) => [\r\n    {name:'clases'                  , typeName:'text'    , editable:false  , inTable:false},\r\n    {name:'cargado'                 , typeName:'boolean' , editable:false  , inTable:false},            \r\n    {name:'reas'                    , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n    {name:'no_reas'                 , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n    {name:'incompletas'             , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n    {name:'vacias'                  , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n    {name:'inhabilitadas'           , typeName:'integer' , editable:false  , aggregate:'sum', inTable:false },\r\n    {name:'comuna'                  , typeName:'bigint'  , title:'comuna'  , inTable:false},\r\n    ...be.caches.tableContent.no_rea_groups.map(x=>(\r\n        {name:x.grupo.replace(/ /g,'_'), typeName:'integer', editable:false}\r\n    ))\r\n];\r\n\r\nexport function areas(context:TableContext):TableDefinition {\r\n    var be=context.be;\r\n    var puedeEditar = context.forDump || context.puede?.campo?.administrar||context.user.rol==='recepcionista';\r\n    return {\r\n        name:'areas',\r\n        elementName:'area',\r\n        editable:puedeEditar,\r\n        hiddenColumns:['clusters', 'clases','cargadas_bkp', 'reas_bkp', 'no_reas_bkp'  \r\n            , 'incompletas_bkp', 'vacias_bkp', 'inhabilitadas_bkp'\r\n        ],\r\n        fields:[\r\n            {name: \"operativo\"              , typeName: \"text\"   , nullable: false, editable: false},\r\n            {name: 'area'                   , typeName: 'integer', nullable: false, editable: false},\r\n            {name:'clusters'                , typeName:'text'    , visible: false},\r\n            {name:'recepcionista'           , typeName:'text', references:'recepcionistas'},\r\n            {name:'encuestador'             , typeName:'text'                    },\r\n            //{name:'recuperador'             , typeName:'text'                    },\r\n            //{name:'supervisor'              , typeName:'text'                    },\r\n            {name:'observaciones_hdr'       , typeName:'text'                      },\r\n            {name:'verificado_rec'          , typeName:'text'                      , aggregate:'count' },\r\n            //{name:'confirmadas'             , typeName:'integer' , editable:false, aggregate:'sum'},\r\n            //{name:'pend_conf'               , typeName:'integer' , editable:false, aggregate:'sum', description:'pendientes de confirmación'},\r\n            {name:'obs_recepcionista'       , typeName:'text'                      },\r\n            ...cuentasFields(be),\r\n            {name:'cargadas_bkp'            , typeName:'integer' , editable:false  },\r\n            {name:'reas_bkp'                , typeName:'integer' , editable:false  },\r\n            {name:'no_reas_bkp'             , typeName:'integer' , editable:false  },\r\n            {name:'incompletas_bkp'         , typeName:'integer' , editable:false  },\r\n            {name:'vacias_bkp'              , typeName:'integer' , editable:false  },\r\n            {name:'inhabilitadas_bkp'       , typeName:'integer' , editable:false  },\r\n        ],\r\n        primaryKey:[\"operativo\",'area'],\r\n        foreignKeys:[\r\n            {references:'operativos', fields:['operativo']},\r\n            {references:'usuarios', fields:[{source:'recepcionista', target:'idper'}], alias:'per_recep', displayFields:[]},\r\n        ],\r\n        softForeignKeys:[\r\n            {references:'encuestadores', fields:[{source:'encuestador', target:'persona'}], alias:'per_encu'},\r\n        ],\r\n        detailTables:[\r\n            {table:'tem_asignacion' , fields:['operativo','area'], abr:'A', refreshParent:true, label:'asignables'},\r\n            {table:`tareas_tem_recepcion`  , fields:['operativo', 'area'], abr:'R', refreshParent:true, label:'recepcion'},\r\n        ],\r\n        sql:{\r\n            isTable:true,\r\n            from:` \r\n            (select a.operativo, a.area, a.recepcionista, ta.asignado encuestador\r\n                ,  a.observaciones_hdr, a.verificado_rec, a.obs_recepcionista\r\n                  --a.operacion_area, a.fecha,\r\n                , a.cargadas_bkp, a.reas_bkp, a.no_reas_bkp, a.incompletas_bkp, a.vacias_bkp, a.inhabilitadas_bkp\r\n                , t.*\r\n                from areas a left join tareas_areas ta on ta.tarea='encu' and ta.area=a.area and ta.operativo=a.operativo, lateral (\r\n                    ${cuentasSql(be, `t.area=a.area /*and tt.tarea='encu'*/`)}\r\n                ) t\r\n            )`\r\n        }\r\n\r\n    };\r\n}\r\n\r\n"]}
|
|
@@ -1,3 +1,10 @@
|
|
|
1
1
|
/// <reference types="backend-plus" />
|
|
2
2
|
import { TableDefinition, TableContext } from "./types-dmencu";
|
|
3
|
-
export
|
|
3
|
+
export type OptsAsignados = {
|
|
4
|
+
rol: 'encu' | 'recu' | 'supe' | null;
|
|
5
|
+
name: string;
|
|
6
|
+
};
|
|
7
|
+
export declare function asignados(context: TableContext, opts?: OptsAsignados): TableDefinition;
|
|
8
|
+
export declare function encuestadores_asignados(context: TableContext): TableDefinition;
|
|
9
|
+
export declare function recuperadores_asignados(context: TableContext): TableDefinition;
|
|
10
|
+
export declare function supervisores_asignados(context: TableContext): TableDefinition;
|
|
@@ -4,16 +4,63 @@
|
|
|
4
4
|
if (v !== undefined) module.exports = v;
|
|
5
5
|
}
|
|
6
6
|
else if (typeof define === "function" && define.amd) {
|
|
7
|
-
define(["require", "exports", "./table-
|
|
7
|
+
define(["require", "exports", "./table-areas"], factory);
|
|
8
8
|
}
|
|
9
9
|
})(function (require, exports) {
|
|
10
10
|
"use strict";
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.
|
|
13
|
-
const
|
|
14
|
-
function
|
|
15
|
-
|
|
12
|
+
exports.supervisores_asignados = exports.recuperadores_asignados = exports.encuestadores_asignados = exports.asignados = void 0;
|
|
13
|
+
const table_areas_1 = require("./table-areas");
|
|
14
|
+
function asignados(context, opts) {
|
|
15
|
+
if (opts == null) {
|
|
16
|
+
opts = {
|
|
17
|
+
name: 'relevador',
|
|
18
|
+
rol: null
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
var { be } = context;
|
|
22
|
+
var q = context.be.db.quoteLiteral;
|
|
23
|
+
var tableDef = {
|
|
24
|
+
name: opts.name,
|
|
25
|
+
elementName: opts.name,
|
|
26
|
+
editable: false,
|
|
27
|
+
fields: [
|
|
28
|
+
{ name: 'tarea', typeName: 'text', },
|
|
29
|
+
{ name: 'asignado', typeName: 'text', title: opts.name },
|
|
30
|
+
{ name: 'apellido', typeName: 'text', },
|
|
31
|
+
{ name: 'nombre', typeName: 'text', },
|
|
32
|
+
...(0, table_areas_1.cuentasFields)(be)
|
|
33
|
+
],
|
|
34
|
+
primaryKey: ['asignado'],
|
|
35
|
+
detailTables: [
|
|
36
|
+
{ table: 'tareas_tem_recepcion', fields: ['tarea', 'asignado'], abr: 'T' }
|
|
37
|
+
],
|
|
38
|
+
sql: {
|
|
39
|
+
from: `(select ta.tarea, u.idper as asignado, u.apellido, u.nombre, t.*
|
|
40
|
+
from usuarios u, tareas ta, lateral (
|
|
41
|
+
${(0, table_areas_1.cuentasSql)(be, `tt.asignado = u.idper and tt.tarea = ta.tarea`)}
|
|
42
|
+
) t
|
|
43
|
+
where true
|
|
44
|
+
${opts.rol ? `and ta.tarea = ${q(opts.rol)}` : ``}
|
|
45
|
+
${context.user.rol == 'recepcionista' ? `and tt.recepcionista = ${q(context.user.idper)}` : ``}
|
|
46
|
+
)`
|
|
47
|
+
},
|
|
48
|
+
hiddenColumns: opts.rol ? ['tarea'] : []
|
|
49
|
+
};
|
|
50
|
+
return tableDef;
|
|
16
51
|
}
|
|
17
|
-
exports.
|
|
52
|
+
exports.asignados = asignados;
|
|
53
|
+
function encuestadores_asignados(context) {
|
|
54
|
+
return asignados(context, { rol: 'encu', name: 'encuestador' });
|
|
55
|
+
}
|
|
56
|
+
exports.encuestadores_asignados = encuestadores_asignados;
|
|
57
|
+
function recuperadores_asignados(context) {
|
|
58
|
+
return asignados(context, { rol: 'recu', name: 'recuperador' });
|
|
59
|
+
}
|
|
60
|
+
exports.recuperadores_asignados = recuperadores_asignados;
|
|
61
|
+
function supervisores_asignados(context) {
|
|
62
|
+
return asignados(context, { rol: 'supe', name: 'supervisor' });
|
|
63
|
+
}
|
|
64
|
+
exports.supervisores_asignados = supervisores_asignados;
|
|
18
65
|
});
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZW5jdWVzdGFkb3Jlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2ZXIvdGFibGUtZW5jdWVzdGFkb3Jlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7SUFBQSxZQUFZLENBQUM7OztJQUliLCtDQUEwRDtJQU8xRCxTQUFnQixTQUFTLENBQUMsT0FBb0IsRUFBRSxJQUFtQjtRQUMvRCxJQUFJLElBQUksSUFBSSxJQUFJLEVBQUU7WUFDZCxJQUFJLEdBQUc7Z0JBQ0gsSUFBSSxFQUFFLFdBQVc7Z0JBQ2pCLEdBQUcsRUFBRSxJQUFJO2FBQ1osQ0FBQTtTQUNKO1FBQ0QsSUFBSSxFQUFFLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUNyQixJQUFJLENBQUMsR0FBRyxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUM7UUFDbkMsSUFBSSxRQUFRLEdBQW9CO1lBQzVCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLFdBQVcsRUFBRSxJQUFJLENBQUMsSUFBSTtZQUN0QixRQUFRLEVBQUUsS0FBSztZQUNmLE1BQU0sRUFBRTtnQkFDSixFQUFDLElBQUksRUFBQyxPQUFPLEVBQWtCLFFBQVEsRUFBQyxNQUFNLEdBQU87Z0JBQ3JELEVBQUMsSUFBSSxFQUFDLFVBQVUsRUFBZSxRQUFRLEVBQUMsTUFBTSxFQUFPLEtBQUssRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFDO2dCQUN0RSxFQUFDLElBQUksRUFBQyxVQUFVLEVBQWUsUUFBUSxFQUFDLE1BQU0sR0FBTztnQkFDckQsRUFBQyxJQUFJLEVBQUMsUUFBUSxFQUFpQixRQUFRLEVBQUMsTUFBTSxHQUFPO2dCQUNyRCxHQUFHLElBQUEsMkJBQWEsRUFBQyxFQUFFLENBQUM7YUFDdkI7WUFDRCxVQUFVLEVBQUUsQ0FBQyxVQUFVLENBQUM7WUFDeEIsWUFBWSxFQUFDO2dCQUNULEVBQUMsS0FBSyxFQUFDLHNCQUFzQixFQUFFLE1BQU0sRUFBQyxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsRUFBRSxHQUFHLEVBQUMsR0FBRyxFQUFDO2FBQ3hFO1lBQ0QsR0FBRyxFQUFDO2dCQUNBLElBQUksRUFBQzs7c0JBRUssSUFBQSx3QkFBVSxFQUFDLEVBQUUsRUFBRSwrQ0FBK0MsQ0FBQzs7O3NCQUcvRCxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFHO3NCQUNoRCxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxlQUFlLENBQUMsQ0FBQyxDQUFDLDBCQUEwQixDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFHO2NBQ3JHO2FBQ0w7WUFDRCxhQUFhLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtTQUMzQyxDQUFBO1FBQ0QsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQztJQXJDRCw4QkFxQ0M7SUFFRCxTQUFnQix1QkFBdUIsQ0FBQyxPQUFvQjtRQUN4RCxPQUFPLFNBQVMsQ0FBQyxPQUFPLEVBQUUsRUFBQyxHQUFHLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQyxhQUFhLEVBQUMsQ0FBQyxDQUFBO0lBQy9ELENBQUM7SUFGRCwwREFFQztJQUVELFNBQWdCLHVCQUF1QixDQUFDLE9BQW9CO1FBQ3hELE9BQU8sU0FBUyxDQUFDLE9BQU8sRUFBRSxFQUFDLEdBQUcsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDLGFBQWEsRUFBQyxDQUFDLENBQUE7SUFDL0QsQ0FBQztJQUZELDBEQUVDO0lBRUQsU0FBZ0Isc0JBQXNCLENBQUMsT0FBb0I7UUFDdkQsT0FBTyxTQUFTLENBQUMsT0FBTyxFQUFFLEVBQUMsR0FBRyxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUMsWUFBWSxFQUFDLENBQUMsQ0FBQTtJQUM5RCxDQUFDO0lBRkQsd0RBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHtUYWJsZURlZmluaXRpb24sIFRhYmxlQ29udGV4dH0gZnJvbSBcIi4vdHlwZXMtZG1lbmN1XCI7XG5cbmltcG9ydCB7IGN1ZW50YXNTcWwsIGN1ZW50YXNGaWVsZHMgfSBmcm9tIFwiLi90YWJsZS1hcmVhc1wiOyAgXG5cbmV4cG9ydCB0eXBlIE9wdHNBc2lnbmFkb3MgPSB7XG4gICAgcm9sOiAnZW5jdSd8J3JlY3UnfCdzdXBlJ3xudWxsXG4gICAgbmFtZTogc3RyaW5nXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhc2lnbmFkb3MoY29udGV4dDpUYWJsZUNvbnRleHQsIG9wdHM/Ok9wdHNBc2lnbmFkb3Mpe1xuICAgIGlmIChvcHRzID09IG51bGwpIHtcbiAgICAgICAgb3B0cyA9IHtcbiAgICAgICAgICAgIG5hbWU6ICdyZWxldmFkb3InLFxuICAgICAgICAgICAgcm9sOiBudWxsXG4gICAgICAgIH1cbiAgICB9XG4gICAgdmFyIHsgYmUgfSA9IGNvbnRleHQ7XG4gICAgdmFyIHEgPSBjb250ZXh0LmJlLmRiLnF1b3RlTGl0ZXJhbDtcbiAgICB2YXIgdGFibGVEZWY6IFRhYmxlRGVmaW5pdGlvbiA9IHtcbiAgICAgICAgbmFtZTogb3B0cy5uYW1lLFxuICAgICAgICBlbGVtZW50TmFtZTogb3B0cy5uYW1lLFxuICAgICAgICBlZGl0YWJsZTogZmFsc2UsXG4gICAgICAgIGZpZWxkczogW1xuICAgICAgICAgICAge25hbWU6J3RhcmVhJyAgICAgICAgICAgICAgICAsIHR5cGVOYW1lOid0ZXh0JyAgICAgLH0sXG4gICAgICAgICAgICB7bmFtZTonYXNpZ25hZG8nICAgICAgICAgICAgICwgdHlwZU5hbWU6J3RleHQnICAgICAsIHRpdGxlOiBvcHRzLm5hbWV9LFxuICAgICAgICAgICAge25hbWU6J2FwZWxsaWRvJyAgICAgICAgICAgICAsIHR5cGVOYW1lOid0ZXh0JyAgICAgLH0sXG4gICAgICAgICAgICB7bmFtZTonbm9tYnJlJyAgICAgICAgICAgICAgICwgdHlwZU5hbWU6J3RleHQnICAgICAsfSxcbiAgICAgICAgICAgIC4uLmN1ZW50YXNGaWVsZHMoYmUpXG4gICAgICAgIF0sXG4gICAgICAgIHByaW1hcnlLZXk6IFsnYXNpZ25hZG8nXSxcbiAgICAgICAgZGV0YWlsVGFibGVzOltcbiAgICAgICAgICAgIHt0YWJsZTondGFyZWFzX3RlbV9yZWNlcGNpb24nLCBmaWVsZHM6Wyd0YXJlYScsICdhc2lnbmFkbyddLCBhYnI6J1QnfVxuICAgICAgICBdLFxuICAgICAgICBzcWw6e1xuICAgICAgICAgICAgZnJvbTpgKHNlbGVjdCB0YS50YXJlYSwgdS5pZHBlciBhcyBhc2lnbmFkbywgdS5hcGVsbGlkbywgdS5ub21icmUsIHQuKlxuICAgICAgICAgICAgICAgIGZyb20gdXN1YXJpb3MgdSwgdGFyZWFzIHRhLCBsYXRlcmFsIChcbiAgICAgICAgICAgICAgICAgICAgJHtjdWVudGFzU3FsKGJlLCBgdHQuYXNpZ25hZG8gPSB1LmlkcGVyIGFuZCB0dC50YXJlYSA9IHRhLnRhcmVhYCl9XG4gICAgICAgICAgICAgICAgKSB0XG4gICAgICAgICAgICAgICAgd2hlcmUgdHJ1ZSBcbiAgICAgICAgICAgICAgICAgICAgJHtvcHRzLnJvbCA/IGBhbmQgdGEudGFyZWEgPSAke3Eob3B0cy5yb2wpfWAgOiBgYCB9XG4gICAgICAgICAgICAgICAgICAgICR7Y29udGV4dC51c2VyLnJvbCA9PSAncmVjZXBjaW9uaXN0YScgPyBgYW5kIHR0LnJlY2VwY2lvbmlzdGEgPSAke3EoY29udGV4dC51c2VyLmlkcGVyKX1gIDogYGAgfSBcbiAgICAgICAgICAgIClgXG4gICAgICAgIH0sXG4gICAgICAgIGhpZGRlbkNvbHVtbnM6IG9wdHMucm9sID8gWyd0YXJlYSddIDogW11cbiAgICB9XG4gICAgcmV0dXJuIHRhYmxlRGVmO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZW5jdWVzdGFkb3Jlc19hc2lnbmFkb3MoY29udGV4dDpUYWJsZUNvbnRleHQpOlRhYmxlRGVmaW5pdGlvbiB7XG4gICAgcmV0dXJuIGFzaWduYWRvcyhjb250ZXh0LCB7cm9sOidlbmN1JywgbmFtZTonZW5jdWVzdGFkb3InfSkgICAgXG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWN1cGVyYWRvcmVzX2FzaWduYWRvcyhjb250ZXh0OlRhYmxlQ29udGV4dCk6VGFibGVEZWZpbml0aW9uIHtcbiAgICByZXR1cm4gYXNpZ25hZG9zKGNvbnRleHQsIHtyb2w6J3JlY3UnLCBuYW1lOidyZWN1cGVyYWRvcid9KSAgICBcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHN1cGVydmlzb3Jlc19hc2lnbmFkb3MoY29udGV4dDpUYWJsZUNvbnRleHQpOlRhYmxlRGVmaW5pdGlvbiB7XG4gICAgcmV0dXJuIGFzaWduYWRvcyhjb250ZXh0LCB7cm9sOidzdXBlJywgbmFtZTonc3VwZXJ2aXNvcid9KSAgICBcbn1cbiJdfQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="backend-plus" />
|
|
2
2
|
import { TableDefinition, TableContext } from "./types-dmencu";
|
|
3
|
-
export declare function personal(context: TableContext, opts
|
|
3
|
+
export declare function personal(context: TableContext, opts?: {
|
|
4
4
|
rol: string;
|
|
5
5
|
name: string;
|
|
6
6
|
} | null): TableDefinition;
|
|
@@ -60,4 +60,4 @@
|
|
|
60
60
|
}
|
|
61
61
|
exports.personal = personal;
|
|
62
62
|
});
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtcGVyc29uYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmVyL3RhYmxlLXBlcnNvbmFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztJQUFBLFlBQVksQ0FBQzs7O0lBSWIsa0NBQWtDO0lBRWxDLFNBQWdCLFFBQVEsQ0FBQyxPQUFvQixFQUFFLElBQW9DOztRQUMvRSxJQUFJLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxPQUFPLEtBQUUsTUFBQSxPQUFPLENBQUMsS0FBSywwQ0FBRSxVQUFVLENBQUMsTUFBTSxDQUFBLENBQUM7UUFDaEYsSUFBSSxNQUFNLEdBQW1CO1lBQ3pCLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBUyxRQUFRLEVBQUUsTUFBTSxFQUFHLFlBQVksRUFBQyxPQUFPLEVBQUM7WUFDbEUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFVLFFBQVEsRUFBRSxNQUFNLEVBQUssTUFBTSxFQUFDLElBQUksRUFBQztZQUMzRCxFQUFFLElBQUksRUFBRSxVQUFVLEVBQVEsUUFBUSxFQUFFLE1BQU0sRUFBSyxNQUFNLEVBQUMsSUFBSSxFQUFDO1lBQzNELEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBYSxRQUFRLEVBQUUsTUFBTSxFQUFLO1lBQy9DLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBWSxRQUFRLEVBQUUsTUFBTSxFQUFLO1lBQy9DLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBUyxRQUFRLEVBQUUsTUFBTSxFQUFLO1lBQy9DLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBVSxRQUFRLEVBQUUsU0FBUyxFQUFFO1lBQy9DLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRyxRQUFRLEVBQUUsTUFBTSxFQUFFO1lBQzVDLHlFQUF5RTtTQUM1RSxDQUFDO1FBQ0YsSUFBSSxJQUFJLEdBQUcsVUFBVSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQSxFQUFFLENBQUEsQ0FBQyxDQUFDLFlBQVksSUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQzs7MENBRXZDLElBQUksSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFBLENBQUMsQ0FBQSxhQUFhLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQSxDQUFDLENBQUEsRUFBRSxFQUFFLENBQUM7UUFDaEgsT0FBTztZQUNILElBQUksRUFBRSxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxVQUFVO1lBQ3JDLFdBQVcsRUFBRSxTQUFTO1lBQ3RCLFFBQVEsRUFBRSxVQUFVO1lBQ3BCLE1BQU07WUFDTixVQUFVLEVBQUUsQ0FBQyxTQUFTLENBQUM7WUFDdkIsV0FBVyxFQUFDO2dCQUNSLEVBQUMsVUFBVSxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMsQ0FBQyxFQUFDLE1BQU0sRUFBQyxlQUFlLEVBQUUsTUFBTSxFQUFDLFNBQVMsRUFBQyxDQUFDLEVBQUUsS0FBSyxFQUFDLGVBQWUsR0FBRzthQUN4RztZQUNELFlBQVksRUFBQztnQkFDVCxFQUFDLEtBQUssRUFBQyxjQUFjLEVBQUUsTUFBTSxFQUFDLENBQUMsU0FBUyxDQUFDLEVBQUUsR0FBRyxFQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUMsT0FBTyxFQUFFLGFBQWEsRUFBQyxJQUFJLEVBQUM7YUFDekY7WUFDRCxHQUFHLEVBQUM7Z0JBQ0EsT0FBTyxFQUFDLEtBQUs7Z0JBQ2IsUUFBUSxFQUFDLElBQUksQ0FBQSxDQUFDLENBQUEsSUFBSSxDQUFBLENBQUMsQ0FBQSxVQUFVLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFBLEVBQUUsQ0FBQSxDQUFDLENBQUMsWUFBWSxJQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDOzt3Q0FFekQ7Z0JBQzVCLElBQUksRUFBQyxJQUFJLENBQUEsQ0FBQyxDQUFBLFdBQVcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUEsRUFBRSxDQUFBLEdBQUcsQ0FBQyxDQUFDLFlBQVksSUFBRSxDQUFDLENBQUMsSUFBSSxPQUFPLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7OzBDQUVqRSxJQUFJLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQSxDQUFDLENBQUEsYUFBYSxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUEsQ0FBQyxDQUFBLEVBQUUsR0FBRyxDQUFBLENBQUMsQ0FBQSxJQUFJO2dCQUN6Rzs7Ozs7O2NBTUY7YUFDTDtTQUNKLENBQUM7SUFDTixDQUFDO0lBN0NELDRCQTZDQyIsInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5pbXBvcnQge1RhYmxlRGVmaW5pdGlvbiwgVGFibGVDb250ZXh0fSBmcm9tIFwiLi90eXBlcy1kbWVuY3VcIjtcbmltcG9ydCB7IEZpZWxkRGVmaW5pdGlvbiB9IGZyb20gXCJyZWwtZW5jXCI7XG5pbXBvcnQgKiBhcyBsaWtlQXIgZnJvbSBcImxpa2UtYXJcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHBlcnNvbmFsKGNvbnRleHQ6VGFibGVDb250ZXh0LCBvcHRzPzp7cm9sOnN0cmluZywgbmFtZTpzdHJpbmd9fG51bGwpOlRhYmxlRGVmaW5pdGlvbiB7XG4gICAgdmFyIGVzRWRpdGFibGUgPSBjb250ZXh0LnVzZXIucm9sID09PSAnYWRtaW4nfHxjb250ZXh0LnB1ZWRlPy5jb25maWd1cmFyLmVkaXRhcjtcbiAgICB2YXIgZmllbGRzOkZpZWxkRGVmaW5pdGlvbltdPVtcbiAgICAgICAgeyBuYW1lOiBcInBlcnNvbmFcIiAgICAgICAsIHR5cGVOYW1lOiBcInRleHRcIiAsIG9yaWdpbmFsTmFtZTpcImlkcGVyXCJ9LFxuICAgICAgICB7IG5hbWU6IFwibm9tYnJlXCIgICAgICAgICwgdHlwZU5hbWU6IFwidGV4dFwiICAgICxpc05hbWU6dHJ1ZX0sXG4gICAgICAgIHsgbmFtZTogXCJhcGVsbGlkb1wiICAgICAgLCB0eXBlTmFtZTogXCJ0ZXh0XCIgICAgLGlzTmFtZTp0cnVlfSxcbiAgICAgICAgeyBuYW1lOiBcInJvbFwiICAgICAgICAgICAsIHR5cGVOYW1lOiBcInRleHRcIiAgICB9LFxuICAgICAgICB7IG5hbWU6IFwiY3VpdFwiICAgICAgICAgICwgdHlwZU5hbWU6IFwidGV4dFwiICAgIH0sXG4gICAgICAgIHsgbmFtZTogXCJ1c3VhcmlvXCIgICAgICAgLCB0eXBlTmFtZTogXCJ0ZXh0XCIgICAgfSxcbiAgICAgICAgeyBuYW1lOiBcImFjdGl2b1wiICAgICAgICAsIHR5cGVOYW1lOiBcImJvb2xlYW5cIiB9LFxuICAgICAgICB7IG5hbWU6IFwicmVjZXBjaW9uaXN0YVwiICwgdHlwZU5hbWU6IFwidGV4dFwiIH0sXG4gICAgICAgIC8vIHsgbmFtZTogXCJqZWZlX2VxdWlwb1wiICAgLCB0eXBlTmFtZTogXCJib29sZWFuXCIgLFwiZGVmYXVsdFZhbHVlXCI6IGZhbHNlfSxcbiAgICBdO1xuICAgIHZhciBmcm9tID0gYHNlbGVjdCAke2xpa2VBcihmaWVsZHMpLm1hcChmPT5mLm9yaWdpbmFsTmFtZXx8Zi5uYW1lKS5qb2luKCcsICcpfVxuICAgICAgICAgICAgICAgIGZyb20gdXN1YXJpb3NcbiAgICAgICAgICAgICAgICB3aGVyZSBpZHBlciBpcyBub3QgbnVsbCAke29wdHMgJiYgb3B0cy5yb2w/YGFuZCByb2wgPSAke2NvbnRleHQuYmUuZGIucXVvdGVMaXRlcmFsKG9wdHMucm9sKX1gOicnfWA7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgbmFtZTogb3B0cyAmJiBvcHRzLm5hbWUgfHwgJ3BlcnNvbmFsJyxcbiAgICAgICAgZWxlbWVudE5hbWU6ICdwZXJzb25hJyxcbiAgICAgICAgZWRpdGFibGU6IGVzRWRpdGFibGUsXG4gICAgICAgIGZpZWxkcyxcbiAgICAgICAgcHJpbWFyeUtleTogWydwZXJzb25hJ10sXG4gICAgICAgIGZvcmVpZ25LZXlzOltcbiAgICAgICAgICAgIHtyZWZlcmVuY2VzOidwZXJzb25hbCcsIGZpZWxkczpbe3NvdXJjZToncmVjZXBjaW9uaXN0YScsIHRhcmdldDoncGVyc29uYSd9XSwgYWxpYXM6J3JlY2VwY2lvbmlzdGEnLCB9XG4gICAgICAgIF0sXG4gICAgICAgIGRldGFpbFRhYmxlczpbXG4gICAgICAgICAgICB7dGFibGU6J3BlcnNvbmFsX3JvbCcsIGZpZWxkczpbJ3BlcnNvbmEnXSwgYWJyOidSJywgbGFiZWw6J3JvbGVzJywgcmVmcmVzaFBhcmVudDp0cnVlfVxuICAgICAgICBdLFxuICAgICAgICBzcWw6e1xuICAgICAgICAgICAgaXNUYWJsZTpmYWxzZSxcbiAgICAgICAgICAgIHZpZXdCb2R5Om9wdHM/bnVsbDpgc2VsZWN0ICR7bGlrZUFyKGZpZWxkcykubWFwKGY9PmYub3JpZ2luYWxOYW1lfHxmLm5hbWUpLmpvaW4oJywgJyl9XG4gICAgICAgICAgICAgICAgZnJvbSB1c3Vhcmlvc1xuICAgICAgICAgICAgICAgIHdoZXJlIGlkcGVyIGlzIG5vdCBudWxsYCxcbiAgICAgICAgICAgIGZyb206b3B0cz9gKHNlbGVjdCAke2xpa2VBcihmaWVsZHMpLm1hcChmPT5gJHtmLm9yaWdpbmFsTmFtZXx8Zi5uYW1lfSBhcyAke2YubmFtZX1gKS5qb2luKCcsICcpfVxuICAgICAgICAgICAgICAgIGZyb20gdXN1YXJpb3NcbiAgICAgICAgICAgICAgICB3aGVyZSBpZHBlciBpcyBub3QgbnVsbCAke29wdHMgJiYgb3B0cy5yb2w/YGFuZCByb2wgPSAke2NvbnRleHQuYmUuZGIucXVvdGVMaXRlcmFsKG9wdHMucm9sKX1gOicnfSlgOm51bGxcbiAgICAgICAgICAgICAgICAvKlxuICAgICAgICAgICAgZmllbGRzOntcbiAgICAgICAgICAgICAgICByb2w6e1xuICAgICAgICAgICAgICAgICAgICBleHByOmAoc2VsZWN0IHN0cmluZ19hZ2cocm9sLCAnLCAnKSBmcm9tIHBlcnNvbmFsX3JvbCB3aGVyZSBwZXJzb25hPXBlcnNvbmFsLnBlcnNvbmEpYFxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgICovXG4gICAgICAgIH1cbiAgICB9O1xufVxuIl19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/// <reference types="backend-plus" />
|
|
2
2
|
import { TableDefinition, TableContext } from "./types-dmencu";
|
|
3
|
-
export declare function tareas(context: TableContext, opts
|
|
3
|
+
export declare function tareas(context: TableContext, opts?: any): TableDefinition;
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
{ name: 'operativo', typeName: 'text' },
|
|
26
26
|
{ name: 'tarea', typeName: 'text' },
|
|
27
27
|
{ name: 'nombre', typeName: 'text' },
|
|
28
|
-
{ name: '
|
|
28
|
+
{ name: 'rol_recepcionista', typeName: 'text', visible: false },
|
|
29
29
|
{ name: 'main_form', typeName: 'text' },
|
|
30
30
|
{ name: 'registra_estado_en_tem', typeName: 'boolean' }
|
|
31
31
|
],
|
|
@@ -44,4 +44,4 @@
|
|
|
44
44
|
}
|
|
45
45
|
exports.tareas = tareas;
|
|
46
46
|
});
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGFyZWFzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3NlcnZlci90YWJsZS10YXJlYXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0lBQUEsWUFBWSxDQUFDOzs7SUFJYixTQUFnQixNQUFNLENBQUMsT0FBb0IsRUFBRSxJQUFTOztRQUNsRCxJQUFJLElBQUksR0FBQyxJQUFJLElBQUUsRUFBRSxDQUFDO1FBQ2xCLElBQUksR0FBRyxHQUFDLElBQUksQ0FBQyxHQUFHLENBQUEsQ0FBQyxDQUFBLE1BQU0sQ0FBQSxDQUFDLENBQUEsRUFBRSxDQUFDO1FBQzNCLElBQUksRUFBRSxHQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDbEIsSUFBSSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sS0FBSSxNQUFBLE1BQUEsT0FBTyxDQUFDLEtBQUssMENBQUUsS0FBSywwQ0FBRSxXQUFXLENBQUEsSUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBRyxlQUFlLENBQUM7UUFDM0csT0FBTztZQUNILElBQUksRUFBQyxHQUFHLEdBQUcsUUFBUTtZQUNuQixTQUFTLEVBQUMsUUFBUTtZQUNsQixXQUFXLEVBQUMsT0FBTztZQUNuQixRQUFRLEVBQUMsV0FBVztZQUNwQixNQUFNLEVBQUM7Z0JBQ0gsRUFBQyxJQUFJLEVBQUMsV0FBVyxFQUFHLFFBQVEsRUFBQyxNQUFNLEVBQUM7Z0JBQ3BDLEVBQUMsSUFBSSxFQUFDLE9BQU8sRUFBRyxRQUFRLEVBQUMsTUFBTSxFQUFDO2dCQUNoQyxFQUFDLElBQUksRUFBQyxRQUFRLEVBQUUsUUFBUSxFQUFDLE1BQU0sRUFBQztnQkFDaEMsRUFBQyxJQUFJLEVBQUMsbUJBQW1CLEVBQUUsUUFBUSxFQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUMsS0FBSyxFQUFDO2dCQUMxRCxFQUFDLElBQUksRUFBQyxXQUFXLEVBQUUsUUFBUSxFQUFDLE1BQU0sRUFBQztnQkFDbkMsRUFBQyxJQUFJLEVBQUMsd0JBQXdCLEVBQUUsUUFBUSxFQUFDLFNBQVMsRUFBQzthQUN0RDtZQUNELFVBQVUsRUFBQyxDQUFDLFdBQVcsRUFBQyxPQUFPLENBQUM7WUFDaEMsV0FBVyxFQUFDO2dCQUNSLEVBQUMsVUFBVSxFQUFDLFlBQVksRUFBRyxNQUFNLEVBQUMsQ0FBQyxXQUFXLENBQUMsRUFBQzthQUNuRDtZQUNELFlBQVksRUFBQztnQkFDVCxFQUFDLEtBQUssRUFBQyxHQUFHLEdBQUcsY0FBYyxFQUFPLE1BQU0sRUFBQyxDQUFDLFdBQVcsRUFBQyxPQUFPLENBQUMsRUFBRSxHQUFHLEVBQUMsR0FBRyxFQUFDO2dCQUN4RSxFQUFDLEtBQUssRUFBQyxHQUFHLEdBQUcsWUFBWSxFQUFTLE1BQU0sRUFBQyxDQUFDLFdBQVcsRUFBQyxPQUFPLENBQUMsRUFBRSxHQUFHLEVBQUMsR0FBRyxFQUFDO2FBQzNFO1lBQ0QsR0FBRyxFQUFDO2dCQUNBLE9BQU8sRUFBQyxDQUFDLElBQUksQ0FBQyxHQUFHO2FBQ3BCO1NBQ0osQ0FBQztJQUNOLENBQUM7SUE5QkQsd0JBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XHJcblxyXG5pbXBvcnQge1RhYmxlRGVmaW5pdGlvbiwgVGFibGVDb250ZXh0fSBmcm9tIFwiLi90eXBlcy1kbWVuY3VcIjtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiB0YXJlYXMoY29udGV4dDpUYWJsZUNvbnRleHQsIG9wdHM/OmFueSk6VGFibGVEZWZpbml0aW9uIHtcclxuICAgIHZhciBvcHRzPW9wdHN8fHt9O1xyXG4gICAgdmFyIG1pcz1vcHRzLm1pcz8nbWlzXyc6Jyc7XHJcbiAgICB2YXIgYmU9Y29udGV4dC5iZTtcclxuICAgIHZhciBwdWVkZUVkaXRhciA9IGNvbnRleHQuZm9yRHVtcCB8fCBjb250ZXh0LnB1ZWRlPy5jYW1wbz8uYWRtaW5pc3RyYXJ8fGNvbnRleHQudXNlci5yb2w9PT0ncmVjZXBjaW9uaXN0YSc7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICAgIG5hbWU6YCR7bWlzfXRhcmVhc2AsXHJcbiAgICAgICAgdGFibGVOYW1lOmB0YXJlYXNgLFxyXG4gICAgICAgIGVsZW1lbnROYW1lOid0YXJlYScsXHJcbiAgICAgICAgZWRpdGFibGU6cHVlZGVFZGl0YXIsXHJcbiAgICAgICAgZmllbGRzOltcclxuICAgICAgICAgICAge25hbWU6J29wZXJhdGl2bycgLCB0eXBlTmFtZTondGV4dCd9LFxyXG4gICAgICAgICAgICB7bmFtZTondGFyZWEnICwgdHlwZU5hbWU6J3RleHQnfSxcclxuICAgICAgICAgICAge25hbWU6J25vbWJyZScsIHR5cGVOYW1lOid0ZXh0J30sXHJcbiAgICAgICAgICAgIHtuYW1lOidyb2xfcmVjZXBjaW9uaXN0YScsIHR5cGVOYW1lOid0ZXh0JywgdmlzaWJsZTpmYWxzZX0sXHJcbiAgICAgICAgICAgIHtuYW1lOidtYWluX2Zvcm0nLCB0eXBlTmFtZTondGV4dCd9LFxyXG4gICAgICAgICAgICB7bmFtZToncmVnaXN0cmFfZXN0YWRvX2VuX3RlbScsIHR5cGVOYW1lOidib29sZWFuJ31cclxuICAgICAgICBdLFxyXG4gICAgICAgIHByaW1hcnlLZXk6WydvcGVyYXRpdm8nLCd0YXJlYSddLFxyXG4gICAgICAgIGZvcmVpZ25LZXlzOltcclxuICAgICAgICAgICAge3JlZmVyZW5jZXM6J29wZXJhdGl2b3MnICwgZmllbGRzOlsnb3BlcmF0aXZvJ119LFxyXG4gICAgICAgIF0sICAgICAgICBcclxuICAgICAgICBkZXRhaWxUYWJsZXM6W1xyXG4gICAgICAgICAgICB7dGFibGU6YCR7bWlzfXRhcmVhc19hcmVhc2AgICAgICwgZmllbGRzOlsnb3BlcmF0aXZvJywndGFyZWEnXSwgYWJyOidBJ30sXHJcbiAgICAgICAgICAgIHt0YWJsZTpgJHttaXN9dGFyZWFzX3RlbWAgICAgICAgLCBmaWVsZHM6WydvcGVyYXRpdm8nLCd0YXJlYSddLCBhYnI6J0UnfSxcclxuICAgICAgICBdLFxyXG4gICAgICAgIHNxbDp7XHJcbiAgICAgICAgICAgIGlzVGFibGU6IW9wdHMubWlzXHJcbiAgICAgICAgfVxyXG4gICAgfTtcclxufVxyXG5cclxuIl19
|
|
@@ -1,3 +1,7 @@
|
|
|
1
1
|
/// <reference types="backend-plus" />
|
|
2
|
+
import { OptsAsignados } from "./table-encuestadores";
|
|
2
3
|
import { TableDefinition, TableContext } from "./types-dmencu";
|
|
3
|
-
export declare function tareas_areas(context: TableContext): TableDefinition;
|
|
4
|
+
export declare function tareas_areas(context: TableContext, opts?: OptsAsignados): TableDefinition;
|
|
5
|
+
export declare function t_encu_areas(context: TableContext): TableDefinition;
|
|
6
|
+
export declare function t_recu_areas(context: TableContext): TableDefinition;
|
|
7
|
+
export declare function t_supe_areas(context: TableContext): TableDefinition;
|
|
@@ -9,9 +9,15 @@
|
|
|
9
9
|
})(function (require, exports) {
|
|
10
10
|
"use strict";
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.tareas_areas = void 0;
|
|
13
|
-
function tareas_areas(context) {
|
|
12
|
+
exports.t_supe_areas = exports.t_recu_areas = exports.t_encu_areas = exports.tareas_areas = void 0;
|
|
13
|
+
function tareas_areas(context, opts) {
|
|
14
14
|
var _a, _b;
|
|
15
|
+
if (opts == null) {
|
|
16
|
+
opts = {
|
|
17
|
+
name: 'relevador',
|
|
18
|
+
rol: null
|
|
19
|
+
};
|
|
20
|
+
}
|
|
15
21
|
var be = context.be;
|
|
16
22
|
var db = be.db;
|
|
17
23
|
var puedeEditar = context.forDump || ((_b = (_a = context.puede) === null || _a === void 0 ? void 0 : _a.campo) === null || _b === void 0 ? void 0 : _b.administrar) || context.user.rol === 'recepcionista';
|
|
@@ -19,11 +25,8 @@
|
|
|
19
25
|
{ name: 'operativo', typeName: 'text', isPk: 1 },
|
|
20
26
|
{ name: 'tarea', typeName: 'text', isPk: 2 },
|
|
21
27
|
{ name: 'area', typeName: 'integer', isPk: 3 },
|
|
22
|
-
{ name: '
|
|
23
|
-
{ name: 'asignado', typeName: 'text', references: 'personal' },
|
|
24
|
-
{ name: 'operacion', typeName: 'text', references: 'operaciones' },
|
|
25
|
-
{ name: 'fecha_asignacion', typeName: 'date' },
|
|
26
|
-
{ name: 'obs_asignante', typeName: 'text' },
|
|
28
|
+
{ name: 'recepcionista', typeName: 'text', references: 'personal' },
|
|
29
|
+
{ name: 'asignado', typeName: 'text', references: 'personal', title: opts.name },
|
|
27
30
|
{ name: 'cargado', typeName: 'boolean', editable: false, inTable: false },
|
|
28
31
|
{ name: 'verificado_recepcion', typeName: 'text' },
|
|
29
32
|
{ name: 'obs_recepcion', typeName: 'text' },
|
|
@@ -37,12 +40,11 @@
|
|
|
37
40
|
foreignKeys: [
|
|
38
41
|
{ references: 'tareas', fields: ['operativo', 'tarea'] },
|
|
39
42
|
{ references: 'areas', fields: ['operativo', 'area'], displayAllFields: true, displayAfterFieldName: 'cargado' },
|
|
40
|
-
{ references: 'usuarios', fields: [{ source: '
|
|
41
|
-
{ references: 'usuarios', fields: [{ source: 'asignado', target: 'idper' }], alias: '
|
|
42
|
-
{ references: 'operaciones', fields: ['operacion'] },
|
|
43
|
+
{ references: 'usuarios', fields: [{ source: 'recepcionista', target: 'idper' }], alias: 'recepcionista' },
|
|
44
|
+
{ references: 'usuarios', fields: [{ source: 'asignado', target: 'idper' }], alias: 'asignado' },
|
|
43
45
|
],
|
|
44
46
|
detailTables: [
|
|
45
|
-
{ table: `
|
|
47
|
+
{ table: `tareas_tem`, fields: ['operativo', 'tarea', 'area'], abr: 'T', refreshParent: true, refreshFromParent: true },
|
|
46
48
|
],
|
|
47
49
|
sql: {
|
|
48
50
|
isTable: true,
|
|
@@ -57,9 +59,31 @@
|
|
|
57
59
|
from tareas_tem tt join tem t using (operativo, enc) where tt.operativo=t.operativo and tt.enc=t.enc and tt.tarea=ta.tarea and t.area=ta.area and t.operativo = ta.operativo
|
|
58
60
|
) tt on true
|
|
59
61
|
)`
|
|
60
|
-
}
|
|
62
|
+
},
|
|
63
|
+
hiddenColumns: []
|
|
61
64
|
};
|
|
62
65
|
}
|
|
63
66
|
exports.tareas_areas = tareas_areas;
|
|
67
|
+
function t_encu_areas(context) {
|
|
68
|
+
var _a;
|
|
69
|
+
var tableDef = tareas_areas(context, { rol: 'encu', name: 'encuestador' });
|
|
70
|
+
(_a = tableDef.hiddenColumns) === null || _a === void 0 ? void 0 : _a.push('areas__encuestador');
|
|
71
|
+
return tableDef;
|
|
72
|
+
}
|
|
73
|
+
exports.t_encu_areas = t_encu_areas;
|
|
74
|
+
function t_recu_areas(context) {
|
|
75
|
+
var _a;
|
|
76
|
+
var tableDef = tareas_areas(context, { rol: 'recu', name: 'recuperador' });
|
|
77
|
+
(_a = tableDef.hiddenColumns) === null || _a === void 0 ? void 0 : _a.push('areas__encuestador');
|
|
78
|
+
return tableDef;
|
|
79
|
+
}
|
|
80
|
+
exports.t_recu_areas = t_recu_areas;
|
|
81
|
+
function t_supe_areas(context) {
|
|
82
|
+
var _a;
|
|
83
|
+
var tableDef = tareas_areas(context, { rol: 'supe', name: 'supervisor' });
|
|
84
|
+
(_a = tableDef.hiddenColumns) === null || _a === void 0 ? void 0 : _a.push('areas__encuestador');
|
|
85
|
+
return tableDef;
|
|
86
|
+
}
|
|
87
|
+
exports.t_supe_areas = t_supe_areas;
|
|
64
88
|
});
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-tareas_areas.js","sourceRoot":"","sources":["../../../src/server/table-tareas_areas.ts"],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\r\n\r\nimport { OptsAsignados } from \"./table-encuestadores\";\r\nimport {TableDefinition, FieldDefinition, TableContext} from \"./types-dmencu\";\r\n\r\nexport function tareas_areas(context:TableContext, opts?:OptsAsignados):TableDefinition {\r\n    if (opts == null) {\r\n        opts = {\r\n            name: 'relevador',\r\n            rol: null\r\n        }\r\n    }\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 fields:FieldDefinition[] = [\r\n        {name:'operativo'               , typeName:'text'   ,isPk:1},\r\n        {name:'tarea'                   , typeName:'text'   ,isPk:2},\r\n        {name:'area'                    , typeName:'integer',isPk:3},\r\n        {name:'recepcionista'           , typeName:'text', references: 'personal'},\r\n        {name:'asignado'                , typeName:'text', references: 'personal', title:opts.name},\r\n        {name:'cargado'                 , typeName:'boolean', editable: false, inTable: false},\r\n        {name:'verificado_recepcion'    , typeName:'text'                      },\r\n        {name:'obs_recepcion'           , typeName:'text'                      },\r\n\r\n    ];\r\n    return {\r\n        name:`tareas_areas`,\r\n        tableName:`tareas_areas`,\r\n        editable:puedeEditar,\r\n        fields,\r\n        primaryKey:['operativo','tarea','area'],\r\n        foreignKeys:[\r\n            {references:'tareas', fields:['operativo','tarea']},\r\n            {references:'areas',  fields:['operativo','area'], displayAllFields:true, displayAfterFieldName:'cargado'},\r\n            {references:'usuarios', fields:[{source:'recepcionista', target:'idper'}], alias:'recepcionista'},\r\n            {references:'usuarios', fields:[{source:'asignado'     , target:'idper'}], alias:'asignado'},\r\n        ],\r\n        detailTables:[\r\n            {table:`tareas_tem`, fields:['operativo', 'tarea', 'area'], abr:'T', refreshParent:true, refreshFromParent:true},\r\n        ],\r\n        sql:{\r\n            isTable: true,\r\n            insertIfNotUpdate:true,\r\n            from:`(\r\n                select t.operativo,t.tarea, a.area\r\n                    ${fields.filter(x=>!(x.isPk||x.inTable==false)).map(x=>`, ta.${db.quoteIdent(x.name)}`).join('')}\r\n                    , cargado\r\n                    from tareas t join areas a on t.operativo=a.operativo\r\n                        left join lateral (select * from tareas_areas where area=a.area and tarea=t.tarea and operativo = t.operativo ) ta on true\r\n                        left join lateral (select bool_or( tt.cargado_dm is not null ) as cargado \r\n                            from tareas_tem tt join tem t using (operativo, enc)  where tt.operativo=t.operativo and tt.enc=t.enc and tt.tarea=ta.tarea and t.area=ta.area and t.operativo = ta.operativo\r\n                        ) tt on true\r\n            )`\r\n        },\r\n        hiddenColumns:[]\r\n    };\r\n}\r\n\r\nexport function t_encu_areas(context:TableContext){\r\n    var tableDef = tareas_areas(context, {rol:'encu', name:'encuestador'}) \r\n    tableDef.hiddenColumns?.push('areas__encuestador');\r\n    return tableDef;\r\n}\r\n\r\nexport function t_recu_areas(context:TableContext){\r\n    var tableDef = tareas_areas(context, {rol:'recu', name:'recuperador'}) \r\n    tableDef.hiddenColumns?.push('areas__encuestador');\r\n    return tableDef;\r\n}\r\n\r\nexport function t_supe_areas(context:TableContext){\r\n    var tableDef = tareas_areas(context, {rol:'supe', name:'supervisor'}) \r\n    tableDef.hiddenColumns?.push('areas__encuestador');\r\n    return tableDef;\r\n}"]}
|