3673 lines
255 KiB
C++
3673 lines
255 KiB
C++
<% /*
|
|
$Revision$
|
|
$Id$
|
|
*/
|
|
%>
|
|
<!-- #include file="../PRS/prs.inc" -->
|
|
<!-- #include file="../Shared/discx3d.inc" -->
|
|
<!-- #include file="../Shared/getkenmerksql.inc" -->
|
|
<%
|
|
|
|
var BIND_RUIMTE = 0x01;
|
|
var BIND_WERKPL = 0x02;
|
|
var BIND_TERREI = 0x04;
|
|
var BIND_AFDELI = 0x08;
|
|
var BIND_PERSOO = 0x10;
|
|
var BIND_INSDEE = 0x20; // Onderdeel
|
|
|
|
ins = {checkAutLevel:
|
|
function (pAutfunction, pUser_key)
|
|
{
|
|
// De DISTINCT in het volgende statement is erg belangrijk
|
|
// We staan multiedit toe van objecten van verschillende disciplines
|
|
// echter alleen als de gebruiker voor al die disciplines exact dezelfde
|
|
// alg_level_write en prs_level_write heeft. Anders wordt het véél te complex.
|
|
var sql = "SELECT distinct fac_gebruiker_alg_level_write, fac_gebruiker_prs_level_write "
|
|
+ " FROM fac_v_webgebruiker w, fac_functie f, ins_deel idd "
|
|
+ " WHERE w.ins_discipline_key = idd.ins_discipline_key "
|
|
+ " AND w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND w.prs_perslid_key = " + pUser_key
|
|
+ " AND fac_functie_code = '"+pAutfunction+"' "
|
|
+ " AND ins_deel_key IN (" + inskeystring + ")"
|
|
|
|
var oRs = Oracle.Execute(sql)
|
|
if (oRs.eof)
|
|
return false;
|
|
|
|
/*globaal*/ alg_level = oRs("fac_gebruiker_alg_level_write").Value;
|
|
/*globaal*/ prs_level = oRs("fac_gebruiker_prs_level_write").Value;
|
|
|
|
if (alg_level==9 && prs_level==9)
|
|
return false; // Alleen leesrechten op *alle* objecten blijkbaar
|
|
|
|
oRs.MoveNext();
|
|
if (!oRs.eof)
|
|
return false; // "Autorisatie te complex! Kies alleen objecten van dezelfde discipline");
|
|
|
|
return true; // Okido
|
|
},
|
|
|
|
setinspectstatus:
|
|
function (deelsrtcontrole_key, ins_inspect_status_key, uitvoerende)
|
|
{ // Zet de status en geef de bijpassende tracking en notificatie.
|
|
var sql = "BEGIN ins.setinspectstatus(" + deelsrtcontrole_key + ", " + ins_inspect_status_key + ", " + user_key + "); END;"
|
|
Oracle.Execute(sql);
|
|
},
|
|
|
|
trackinspectupdate:
|
|
// Let op: dit moet wellicht niet altijd (aangeroepen na save)
|
|
function (deelsrtcontrole_key, ptxt)
|
|
{
|
|
shared.trackaction("INSCUP", deelsrtcontrole_key, ptxt);
|
|
},
|
|
|
|
tracksrtdeelupdate:
|
|
function (srtdeel_key, ptxt)
|
|
{
|
|
shared.trackaction("INSSUP", srtdeel_key, ptxt);
|
|
},
|
|
|
|
getBindingItemString:
|
|
function(bind, bind_key, parent_key)
|
|
{
|
|
var sql;
|
|
var binding_item = L("lcl_unknown");
|
|
switch (bind)
|
|
{
|
|
case 'A':
|
|
{
|
|
sql = "SELECT " + S("prs_dep_string")
|
|
+ " FROM prs_v_afdeling d"
|
|
+ " WHERE d.prs_afdeling_key = " + bind_key;
|
|
break;
|
|
}
|
|
|
|
case 'P':
|
|
{
|
|
sql = "SELECT prs_perslid_naam_full"
|
|
+ " FROM prs_v_perslid_fullnames_all pf"
|
|
+ " WHERE pf.prs_perslid_key = " + bind_key;
|
|
break;
|
|
}
|
|
|
|
case 'C':
|
|
{
|
|
sql = "SELECT cp.prs_contactpersoon_naam"
|
|
+ " FROM prs_contactpersoon cp"
|
|
+ " WHERE cp.prs_contactpersoon_key = " + bind_key;
|
|
break;
|
|
}
|
|
|
|
case 'R':
|
|
{
|
|
sql = "SELECT o.alg_plaatsaanduiding || DECODE(o.alg_plaatsomschrijving, '','' ,' (' || o.alg_plaatsomschrijving || ')')"
|
|
+ " FROM ins_v_alg_overzicht o "
|
|
+ " WHERE o.alg_ruimte_key = " + bind_key;
|
|
break;
|
|
}
|
|
|
|
case 'W':
|
|
{
|
|
sql = "SELECT pa.alg_plaatsaanduiding || DECODE(a.alg_ruimte_omschrijving,NULL,'',' (' || a.alg_ruimte_omschrijving || ')')"
|
|
+ " FROM alg_ruimte a"
|
|
+ ", ins_v_alg_overzicht pa"
|
|
+ " WHERE a.alg_ruimte_key = pa.alg_ruimte_key"
|
|
+ " AND pa.prs_werkplek_key = " + bind_key;
|
|
break;
|
|
}
|
|
|
|
case 'T':
|
|
{
|
|
sql = "SELECT pa.alg_plaatsaanduiding || DECODE(t.alg_terreinsector_omschrijving,NULL,'',' (' || t.alg_terreinsector_omschrijving || ')')"
|
|
+ " FROM alg_terreinsector t"
|
|
+ ", ins_v_alg_overzicht pa"
|
|
+ " WHERE t.alg_terreinsector_key = pa.alg_onroerendgoed_keys"
|
|
+ " AND t.alg_terreinsector_key = " + bind_key;
|
|
break;
|
|
}
|
|
|
|
case 'I':
|
|
{
|
|
sql = "SELECT ins_deel_omschrijving"
|
|
+ " FROM ins_deel d"
|
|
+ " WHERE d.ins_deel_key = " + parent_key;
|
|
break;
|
|
}
|
|
|
|
default: INTERNAL_ERROR_UNKNOWN_BIND;
|
|
}
|
|
oRs = Oracle.Execute(sql);
|
|
if (!oRs.eof)
|
|
binding_item = oRs(0).Value;
|
|
return binding_item;
|
|
},
|
|
|
|
getGGD:
|
|
function(obj_keys)
|
|
{
|
|
if (obj_keys.length > 0)
|
|
{
|
|
var sql = "SELECT dg.prs_perslid_key"
|
|
+ " , dg.prs_afdeling_key"
|
|
+ " , dg.alg_locatie_key"
|
|
+ " , dg.alg_gebouw_key"
|
|
+ " , dg.alg_terreinsector_key"
|
|
+ " , dg.alg_verdieping_key"
|
|
+ " , dg.alg_ruimte_key"
|
|
+ " , " + S("alg_loc_string") + " loc_oms"
|
|
+ " , g.alg_gebouw_code || ' ' || g.alg_gebouw_naam" + " geb_oms"
|
|
+ " , t.alg_terreinsector_code || ' ' || t.alg_terreinsector_naam" + " ter_oms"
|
|
+ " , v.alg_verdieping_omschrijving ver_oms"
|
|
+ " , g.alg_gebouw_code || '-' || v.alg_verdieping_code || '-' || r.alg_ruimte_nr rui_oms"
|
|
+ " FROM ins_v_deel_gegevens_keys dg"
|
|
+ " , alg_v_aanweziglocatie l"
|
|
+ " , alg_v_aanweziggebouw g"
|
|
+ " , alg_v_aanwezigterreinsector t"
|
|
+ " , alg_v_aanwezigverdieping v"
|
|
+ " , alg_v_aanwezigruimte r"
|
|
+ " WHERE dg.alg_locatie_key = l.alg_locatie_key(+)"
|
|
+ " AND dg.alg_gebouw_key = g.alg_gebouw_key(+)"
|
|
+ " AND dg.alg_terreinsector_key = t.alg_terreinsector_key(+)"
|
|
+ " AND dg.alg_verdieping_key = v.alg_verdieping_key(+)"
|
|
+ " AND dg.alg_ruimte_key = r.alg_ruimte_key(+)"
|
|
+ " AND dg.ins_deel_key IN (" + obj_keys.join(",") + ")"
|
|
+ " ORDER BY prs_perslid_key DESC"; // Eerst de plaatsgebonden objecten.
|
|
var oRs = Oracle.Execute(sql);
|
|
var nrPlaatsGebondenObjects = 0;
|
|
var diffL = false; // Meegegeven objecten bevinden zich op verschillende locaties.
|
|
var diffG = false; // Meegegeven objecten bevinden zich in verschillende gebouwen.
|
|
var diffT = false; // Meegegeven objecten bevinden zich in verschillende terreinen.
|
|
var diffV = false; // Meegegeven objecten bevinden zich op verschillende verdiepingen.
|
|
var diffR = false; // Meegegeven objecten bevinden zich in verschillende ruimten.
|
|
var prs_key = oRs("prs_perslid_key").Value;
|
|
var afd_key = oRs("prs_afdeling_key").Value;
|
|
var loc_key = oRs("alg_locatie_key").Value;
|
|
var geb_key = oRs("alg_gebouw_key").Value;
|
|
var ter_key = oRs("alg_terreinsector_key").Value;
|
|
var ver_key = oRs("alg_verdieping_key").Value;
|
|
var rui_key = oRs("alg_ruimte_key").Value;
|
|
var loc_oms = oRs("loc_oms").Value;
|
|
var geb_oms = oRs("geb_oms").Value;
|
|
var ter_oms = oRs("ter_oms").Value;
|
|
var ver_oms = oRs("ver_oms").Value;
|
|
var rui_oms = oRs("rui_oms").Value;
|
|
if (prs_key == null && afd_key == null)
|
|
nrPlaatsGebondenObjects++;
|
|
oRs.MoveNext();
|
|
while (!oRs.eof)
|
|
{
|
|
if (oRs("prs_perslid_key").Value == null && oRs("prs_afdeling_key").Value == null)
|
|
{ // Object is niet persoons- of afdelingsgebonden.
|
|
nrPlaatsGebondenObjects++;
|
|
if (!diffL && loc_key != oRs("alg_locatie_key").Value)
|
|
diffL = diffG = diffV = diffR = true;
|
|
else if (!diffG && (geb_key != oRs("alg_gebouw_key").Value || oRs("alg_gebouw_key").Value == null))
|
|
diffG = diffV = diffR = true;
|
|
|
|
if (!diffT && (ter_key != oRs("alg_terreinsector_key").Value || oRs("alg_terreinsector_key").Value == null))
|
|
diffT = true;
|
|
|
|
if (!diffV && ver_key != oRs("alg_verdieping_key").Value)
|
|
diffV = diffR = true;
|
|
else if (!diffR && rui_key != oRs("alg_ruimte_key").Value)
|
|
diffR = true;
|
|
}
|
|
oRs.MoveNext();
|
|
}
|
|
oRs.Close();
|
|
if (nrPlaatsGebondenObjects == 0)
|
|
return null; // Er zijn geen plaatsgebonden objecten gevonden.
|
|
else if (!diffR)
|
|
return {alg_key: rui_key, alg_type: "R", alg_oms: rui_oms, ver_key: ver_key, ver_oms: ver_oms, geb_key: geb_key, geb_oms: geb_oms, loc_key: loc_key, loc_oms: loc_oms};
|
|
else if (!diffV)
|
|
return {alg_key: ver_key, alg_type: "V", alg_oms: ver_oms, geb_key: geb_key, geb_oms: geb_oms, loc_key: loc_key, loc_oms: loc_oms};
|
|
else if (!diffT)
|
|
return {alg_key: ter_key, alg_type: "T", alg_oms: ter_oms, loc_key: loc_key, loc_oms: loc_oms};
|
|
else if (!diffG)
|
|
return {alg_key: geb_key, alg_type: "G", alg_oms: geb_oms, loc_key: loc_key, loc_oms: loc_oms};
|
|
else if (!diffL)
|
|
return {alg_key: loc_key, alg_type: "L", alg_oms: loc_oms};
|
|
else
|
|
return null;
|
|
}
|
|
else
|
|
return null;
|
|
},
|
|
|
|
getinspectstatustext:
|
|
function (p)
|
|
{
|
|
var statustekst = "??";
|
|
var s = parseInt(p, 10);
|
|
switch (s) {
|
|
case 0: { statustekst = L("lcl_ins_controle_pending"); break; }
|
|
case 2: { statustekst = L("lcl_ins_controle_gestart"); break; }
|
|
case 5: { statustekst = L("lcl_ins_controle_act_req"); break; }
|
|
case 6: { statustekst = L("lcl_ins_controle_afgerond"); break; }
|
|
}
|
|
if (__Logging> 0)
|
|
statustekst += " ("+String(p)+")";
|
|
return statustekst;
|
|
},
|
|
|
|
getscenariostatustext:
|
|
function (p)
|
|
{
|
|
var statustekst = "??";
|
|
var s = parseInt(p, 10);
|
|
switch (s) {
|
|
case 0: { statustekst = L("lcl_ins_new"); break; }
|
|
case 6: { statustekst = L("lcl_ins_verwerkt"); break; }
|
|
}
|
|
if (__Logging > 0)
|
|
statustekst += " (" + String(p) + ")";
|
|
return statustekst;
|
|
},
|
|
|
|
updateKenmerkdeel:
|
|
function(ins_key, params)
|
|
{ // Wijzigbare flexkenmerken altijd opslaan
|
|
params = params || [];
|
|
currentKenmerkenSQL = "SELECT v.ins_kenmerk_key, v.ins_kenmerkdeel_waarde"
|
|
+ " FROM ins_kenmerkdeel v"
|
|
+ " WHERE v.ins_kenmerkdeel_verwijder IS NULL"
|
|
+ " AND v.ins_deel_key = " + ins_key;
|
|
|
|
allKenmerkenSQL = "SELECT " + lcl.xsql('t.ins_srtkenmerk_omschrijving', 't.ins_srtkenmerk_key') + " kenmerk_omschrijving"
|
|
+ ", t.ins_srtkenmerk_kenmerktype kenmerk_kenmerktype"
|
|
+ ", t.ins_srtkenmerk_systeem kenmerk_systeem"
|
|
+ ", k.ins_kenmerk_toonbaar kenmerk_readonly"
|
|
+ ", k.ins_kenmerk_uniek kenmerk_uniek"
|
|
+ ", fac_kenmerkdomein_key"
|
|
+ " FROM ins_kenmerk k, "
|
|
+ " ins_srtkenmerk t"
|
|
+ " WHERE k.ins_srtkenmerk_key = t.ins_srtkenmerk_key"
|
|
+ " AND k.ins_kenmerk_key = "; /* wordt in saveFlexkenmerken uitgebreid */
|
|
|
|
var flextrack = saveFlexKenmerken(ins_key,
|
|
{ kenmerkTable: "ins_kenmerkdeel",
|
|
kenmerkParentKey : "ins_deel_key",
|
|
kenmerkWaarde: "ins_kenmerkdeel_waarde",
|
|
kenmerkKey: "ins_kenmerk_key",
|
|
currentKenmerkenSQL: currentKenmerkenSQL,
|
|
allKenmerkenSQL: allKenmerkenSQL,
|
|
requestQF: Request.Form,
|
|
isNew: params.isnew,
|
|
flexPath: "INS/I",
|
|
multiMode: params.multimode,
|
|
tracking: true,
|
|
module: "INS"
|
|
});
|
|
return flextrack;
|
|
},
|
|
|
|
isSleCil:
|
|
// Niveau kan de volgende waarden hebben:
|
|
// null : ins_deel (niet meegegeven)
|
|
// 'S' : ins_srtdeel
|
|
// 'G' : ins_srtgroup (Not used yet)
|
|
// 'D' : ins_discipline
|
|
function(key, niveau)
|
|
{ // Is de key een ins_deel_key of ins_srtdeel_key vsleutel of een cilinder
|
|
var isSC;
|
|
switch (niveau)
|
|
{
|
|
case "S": // ins_srtdeel
|
|
var sql = "SELECT sd.ins_srtgroep_key"
|
|
+ " FROM ins_srtdeel sd"
|
|
+ " WHERE sd.ins_srtdeel_key = " + key;
|
|
break;
|
|
case "G": // ins_srtgroep
|
|
var sql = "SELECT sg.ins_srtgroep_key"
|
|
+ " FROM ins_srtgroep sg"
|
|
+ " WHERE sg.ins_srtgroep_key = " + key;
|
|
break;
|
|
case "D": // ins_discipline
|
|
var sql = "SELECT sg.ins_srtgroep_key"
|
|
+ " FROM ins_srtgroep sg"
|
|
+ " WHERE sg.ins_discipline_key = " + key;
|
|
break;
|
|
default: // ins_deel
|
|
var sql = "SELECT sd.ins_srtgroep_key"
|
|
+ " FROM ins_deel d"
|
|
+ " , ins_srtdeel sd"
|
|
+ " WHERE d.ins_srtdeel_key = sd.ins_srtdeel_key"
|
|
+ " AND d.ins_deel_key = " + key;
|
|
}
|
|
var oRs = Oracle.Execute(sql);
|
|
var groep_key = oRs("ins_srtgroep_key").Value;
|
|
oRs.Close;
|
|
return (groep_key == S("sle_ins_srt_groep_key") || groep_key == S("cil_ins_srt_groep_key"));
|
|
},
|
|
|
|
//PF: idee om dit te versnellen door voorkennis te vergaren. De selecties zijn erg zwaar
|
|
// eerste stap: in singlerecordmode zo weinig mogelijk query doen.
|
|
// Bepaalt of we op het één object schrijfrechten hebben
|
|
// return True als het mag, false als het niet mag
|
|
// Pas op: parameter alg_key kan ook prs_perslid of afdeling zijn afhankelijk van bind!!
|
|
checkAutSQL:
|
|
function (pUser_key, bind, alg_key, disc_key)
|
|
{
|
|
// Helaas, we moeten 'ingewikkeld' gaan controleren
|
|
// We weten ondertussen al de fac_gebruiker_alg_level_write dus het volgende kan
|
|
// heel efficient.....
|
|
// Alle ruimtes op maximaal afstand 'alg_level' van *mij*
|
|
var fac_v_my_disc_onrgoed_write = ""
|
|
+ "SELECT a.alg_ruimte_key"
|
|
+ " FROM alg_v_onrgoed_familie a,"
|
|
+ " alg_v_onrgoed_familie aa,"
|
|
+ " alg_v_my_room mr"
|
|
+ " WHERE mr.alg_ruimte_key = aa.alg_ruimte_key"
|
|
+ " AND mr.prs_perslid_key = " + pUser_key
|
|
+ " AND a.alg_onrgoed_elder_key = aa.alg_onrgoed_elder_key"
|
|
+ " AND aa.niveau = a.niveau" // Noodzakelijk want ALG_LOCATIE heeft eigen sequence
|
|
+ " AND aa.niveau >= " + alg_level
|
|
|
|
// Alle afdelingen op maximaal afstand 'alg_level' van *mij*
|
|
var fac_v_my_disc_afdelingen_write = ""
|
|
+ "SELECT a.prs_afdeling_key "
|
|
+ " FROM prs_v_afdeling_familie a, "
|
|
+ " prs_v_afdeling_familie aa "
|
|
+ " WHERE aa.prs_afdeling_key = " + user.prs_afdeling_key()
|
|
+ " AND a.prs_afdeling_elder_key = aa.prs_afdeling_elder_key "
|
|
+ " AND aa.niveau = a.niveau "
|
|
+ " AND aa.niveau >= " + prs_level
|
|
|
|
switch (bind)
|
|
{
|
|
case 'R':
|
|
case 'W':
|
|
case 'T':
|
|
if (alg_level == 9) return false; // Zeker niet op basis van alg_scope
|
|
if (alg_level == -1) return true; // Zeker wel op basis van alg_scope
|
|
if (bind == 'T') // Speciaal geval voor terreinsectoren
|
|
{
|
|
if (alg_level > 2) return false; // Zeker niet op basis van alg_scope
|
|
rsql = " SELECT 1"
|
|
+ " FROM alg_v_my_location avml, alg_terreinsector ats"
|
|
+ " WHERE avml.alg_locatie_key = ats.alg_locatie_key"
|
|
+ " AND avml.prs_perslid_key = " + pUser_key
|
|
+ " AND ats.alg_terreinsector_key = " + alg_key
|
|
}
|
|
else
|
|
rsql = " SELECT 1" // plaatsgebonden en gebruiker heeft een plaats (werkplek)
|
|
+ " FROM ("+fac_v_my_disc_onrgoed_write+") oga"
|
|
+ " WHERE oga.alg_ruimte_key = " + alg_key
|
|
break;
|
|
|
|
case 'P':
|
|
if (prs_level == 9) return false; // Zeker niet op basis van prs_scope
|
|
if (prs_level == -1) return true; // Zeker wel op basis van prs_scope
|
|
rsql= " SELECT 2" // persoonsgebonden
|
|
+ " FROM ("+fac_v_my_disc_afdelingen_write+") aa, prs_perslid p"
|
|
+ " WHERE p.prs_perslid_key = " + alg_key
|
|
+ " AND aa.prs_afdeling_key = p.prs_afdeling_key"
|
|
+ " AND rownum=1";
|
|
break;
|
|
|
|
case 'A':
|
|
if (prs_level == 9) return false; // Zeker niet op basis van prs_scope
|
|
if (prs_level == -1) return true; // Zeker wel op basis van prs_scope
|
|
rsql= " SELECT 3" // afdelingsgebonden
|
|
+ " FROM ("+fac_v_my_disc_afdelingen_write+") aa"
|
|
+ " WHERE aa.prs_afdeling_key = " + alg_key
|
|
+ " AND rownum=1";
|
|
break;
|
|
}
|
|
return !(Oracle.Execute(rsql).eof);
|
|
},
|
|
|
|
// Check de autorisatie van alle objecten. We eisen overal schrijfrechten op
|
|
// We testen per unieke ins_alg_ruimte_type, ins_alg_ruimte_key, ins_discipline_key
|
|
// waardoor er een sterke performanceverbetering is als bijvoorbeeld
|
|
// alle objecten van dezelfde discipline zijn en van dezelfde ruimte/persoon/afdeling
|
|
checkAutSQLMultiple:
|
|
function (autfunction)
|
|
{
|
|
var sql, oRs;
|
|
sql = "SELECT ins_alg_ruimte_type, ins_alg_ruimte_key, ins_discipline_key "
|
|
+ " FROM ins_deel WHERE ins_deel_key IN (" + inskeystring + ")"
|
|
+ " GROUP BY ins_alg_ruimte_type, ins_alg_ruimte_key, ins_discipline_key";
|
|
oRs = Oracle.Execute( sql );
|
|
|
|
while (mayEdit && !oRs.Eof)
|
|
{
|
|
var bind = oRs("ins_alg_ruimte_type").Value;
|
|
var alg_key = oRs("ins_alg_ruimte_key").Value; // Kan ook prs_perslid of afdeling zijn!!
|
|
var disc_key = oRs("ins_discipline_key").Value;
|
|
|
|
mayEdit = ins.checkAutSQL(user_key, bind, alg_key, disc_key);
|
|
|
|
oRs.moveNext();
|
|
}
|
|
return mayEdit;
|
|
},
|
|
|
|
ins_disciplineinfo:
|
|
function _ins_disciplineinfo(ins_discipline_key) {
|
|
var sql = "SELECT ins_discipline_key"
|
|
+ " , (SELECT COUNT(*)"
|
|
+ " FROM fac_faq ff"
|
|
+ " , mld_stdmeldingfaq sf"
|
|
+ " WHERE ff.fac_faq_key = sf.fac_faq_key"
|
|
+ " AND sf.ins_discipline_key = md.ins_discipline_key"
|
|
+ " AND BITAND (fac_faq_level, 1) = 1" // Voor fe
|
|
+ " AND fac_faq_datum < SYSDATE"
|
|
+ " AND (fac_faq_lang = " + safe.quoted_sql(user_lang) + " OR fac_faq_lang IS NULL)) aantal_fefaq"
|
|
+ " , (SELECT COUNT(*)"
|
|
+ " FROM fac_faq ff"
|
|
+ " , mld_stdmeldingfaq sf"
|
|
+ " WHERE ff.fac_faq_key = sf.fac_faq_key"
|
|
+ " and sf.ins_discipline_key = md.ins_discipline_key"
|
|
+ " AND BITAND (fac_faq_level, 2) = 2" // Voor fo
|
|
+ " AND fac_faq_datum < SYSDATE"
|
|
+ " AND (fac_faq_lang = " + safe.quoted_sql(user_lang) + " OR fac_faq_lang IS NULL)) aantal_fofaq"
|
|
+ " , ins_discipline_module"
|
|
+ " , ins_discipline_omschrijving"
|
|
+ " , ins_discipline_min_level"
|
|
+ " , ins_srtdiscipline_key"
|
|
+ " , ins_discipline_kpnverplicht"
|
|
+ " , prs_kostensoort_key"
|
|
+ " , ins_discipline_email"
|
|
+ " , ins_discipline_btw"
|
|
+ " , ins_discipline_opmerking"
|
|
+ " , ins_discipline_ktopercentage"
|
|
+ " , ins_discipline_ktodrempel"
|
|
+ " , ins_discipline_volgnr"
|
|
+ " FROM mld_discipline md"
|
|
+ " WHERE md.ins_discipline_key = " + ins_discipline_key;
|
|
var oRs = Oracle.Execute(sql);
|
|
|
|
var result = { ins_discipline_key: oRs("ins_discipline_key").Value,
|
|
aantal_fefaq: oRs("aantal_fefaq").Value,
|
|
aantal_fofaq: oRs("aantal_fofaq").Value,
|
|
module: oRs("ins_discipline_module").Value,
|
|
omschrijving: oRs("ins_discipline_omschrijving").Value,
|
|
min_level: oRs("ins_discipline_min_level").Value,
|
|
ins_srtdiscipline_key: oRs("ins_srtdiscipline_key").Value,
|
|
kpnverplicht: oRs("ins_discipline_kpnverplicht").Value,
|
|
prs_kostensoort_key: oRs("prs_kostensoort_key").Value,
|
|
email: oRs("ins_discipline_email").Value,
|
|
btw: oRs("ins_discipline_btw").Value,
|
|
opmerking: oRs("ins_discipline_opmerking").Value,
|
|
ktopercentage: oRs("ins_discipline_ktopercentage").Value,
|
|
ktodrempel: oRs("ins_discipline_ktodrempel").Value,
|
|
volgnr: oRs("ins_discipline_volgnr").Value
|
|
};
|
|
|
|
if (result.aantal_fefaq > 0)
|
|
{
|
|
result.canFAQUSEread = user.checkAutorisation("WEB_FAQUSE", true)!=null;
|
|
}
|
|
if (result.aantal_fofaq > 0)
|
|
{
|
|
result.canFAQFOFread = user.checkAutorisation("WEB_FAQFOF", true)!=null;
|
|
}
|
|
oRs.Close();
|
|
|
|
return result;
|
|
},
|
|
|
|
func_enabled_deel: // Wat mag ik zoal op dit specifieke object?
|
|
// autodetect sleutels
|
|
function _func_enabled_deel(pins_deel_key, params)
|
|
{
|
|
var isql = "SELECT d.ins_discipline_key"
|
|
+ " , d.ins_alg_ruimte_key"
|
|
+ " , d.ins_alg_ruimte_type"
|
|
+ " , d.ins_alg_ruimte_key_org"
|
|
+ " , d.ins_alg_ruimte_type_org"
|
|
+ " , isd.ins_srtgroep_key"
|
|
+ " , d.ins_deel_actief"
|
|
+ " , d.prs_perslid_key_beh"
|
|
+ " FROM ins_deel d"
|
|
+ " , ins_srtdeel isd"
|
|
+ " WHERE d.ins_srtdeel_key = isd.ins_srtdeel_key"
|
|
+ " AND d.ins_deel_key = " + pins_deel_key;
|
|
var ioRs = Oracle.Execute(isql);
|
|
var srtgroep_key = ioRs("ins_srtgroep_key").Value;
|
|
var actief = ioRs("ins_deel_actief").Value == 1;
|
|
var beheerder_key = ioRs("prs_perslid_key_beh").value;
|
|
var objectbeheerder = S("ins_can_edit_own_objects") && (beheerder_key == user_key);
|
|
|
|
var fronto = params && params.urole? params.urole == "fo" : false;
|
|
var isSleCil = (srtgroep_key == S("sle_ins_srt_groep_key") || srtgroep_key == S("cil_ins_srt_groep_key"));
|
|
if (isSleCil)
|
|
{
|
|
var alg_key = ioRs("ins_alg_ruimte_key_org").Value? ioRs("ins_alg_ruimte_key_org").Value : ioRs("ins_alg_ruimte_key").Value;
|
|
var iresult = user.func_enabled("SLE",
|
|
null, // ins_discipline doet niet ter zake
|
|
alg_key, // alg_key
|
|
null); // hier zou alleen een prs_key in mogen, we testen zo afzonderlijk
|
|
|
|
var readslebof = iresult.canRead("WEB_SLEBOF");
|
|
iresult.readslebof = readslebof;
|
|
iresult.canRead = readslebof; // Lezen
|
|
iresult.canReadAny = iresult.canRead;
|
|
|
|
var writeslebof = iresult.canWrite("WEB_SLEBOF");
|
|
var writeslefof = iresult.canWrite("WEB_SLEFOF");
|
|
iresult.canChange = readslebof; // Wijzigen
|
|
iresult.writeslebof = writeslebof;
|
|
iresult.writeslefof = writeslefof;
|
|
iresult.canDelete = writeslebof; // Verwijderen
|
|
iresult.canChange = writeslebof; // Wijzigen
|
|
iresult.canChangeOwn = (iresult.readuse || iresult.readman) && objectbeheerder;
|
|
iresult.canChangeAlg = (iresult.canChange && !fronto) || iresult.canChangeOwn; // Wijzigen algemene gegevens
|
|
iresult.canCopy = writeslebof; // Kopiëren
|
|
iresult.isSleCil = true;
|
|
}
|
|
else // Gewone objecten
|
|
{
|
|
var iresult = ins.func_enabled_scope(ioRs("ins_discipline_key").Value,
|
|
ioRs("ins_alg_ruimte_type").Value,
|
|
ioRs("ins_alg_ruimte_key").Value,
|
|
params);
|
|
if (!iresult)
|
|
return { canReadAny: false }; // Aanroeper moet hier (of andere canFunctie) op controleren
|
|
// Vanuit PDA wordt dan eventueel met melding (of reservering) op dit object
|
|
// Daarom niet al te hard er uit klappen hier.
|
|
iresult.canReadAny = true;
|
|
iresult.canChangeOwn = (iresult.readuse || iresult.readman) && objectbeheerder;
|
|
iresult.canChange = iresult.canChange || iresult.canChangeOwn;
|
|
iresult.canChangeAlg = iresult.canChangeAlg || iresult.canChangeOwn;
|
|
iresult.writeslebof = false;
|
|
iresult.writeslefof = false;
|
|
|
|
if (params && params.srtcont_key > 0)
|
|
{
|
|
// Als scenario niet is meegegeven dan default 1 nemen.
|
|
params.scen_key = params.scen_key || 1;
|
|
var sql = "SELECT idsc.ins_deelsrtcontrole_key"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " WHERE idsc.ins_deel_key = " + pins_deel_key
|
|
+ " AND idsc.ins_srtcontrole_key = " + params.srtcont_key
|
|
+ " AND idsc.ins_deelsrtcontrole_status IN (6)"
|
|
+ " AND idsc.ins_scenario_key = 1";
|
|
var oRs = Oracle.Execute(sql);
|
|
var hasInspect = !oRs.eof;
|
|
oRs.Close();
|
|
|
|
var sql = "SELECT xcp.ins_srtcontrole_periode"
|
|
+ " , xcp.ctr_discipline_key"
|
|
+ " , xcp.ctr_ismjob"
|
|
+ " FROM ins_v_defined_inspect_xcp xcp"
|
|
+ " WHERE xcp.ins_srtcontrole_key = " + params.srtcont_key
|
|
+ " AND xcp.ins_deel_key = " + pins_deel_key
|
|
+ " AND xcp.ins_scenario_key = 1"
|
|
var oRs = Oracle.Execute(sql);
|
|
var periode = oRs("ins_srtcontrole_periode").Value;
|
|
var ctr_discipline_key = oRs("ctr_discipline_key").Value;
|
|
var ctr_ismjob = oRs("ctr_ismjob").Value == 1;
|
|
oRs.Close();
|
|
|
|
var ins_deelsrtcontrole_status = -1;
|
|
var vervaldatum = null;
|
|
var isc_options = 0;
|
|
var vervallen = false;
|
|
var invoerAfterNext = false;
|
|
var isFreezeYear = false;
|
|
if (periode > 0)
|
|
{
|
|
var mjb_freeze_year = S("mjb_freeze_year");
|
|
var mjb_start_year = S("mjb_start_year");
|
|
// Voor het bepalen van de autorisatie voor inspecties, moet gekeken worden naar de gegevens van de Active Situatie (AS).
|
|
var sql = "SELECT insp.ins_deelsrtcontrole_key"
|
|
+ " , insp.ins_deelsrtcontrole_status"
|
|
+ " , insp.vervaldatum"
|
|
+ " , insp.isc_mode"
|
|
+ " , options"
|
|
// Moment inspectie pas kunnen opslaan op of na geplande inspectiedatum.
|
|
// Is in de moment modus de invoer na het volgende berekende inspectietijdstip? Voor interval modus is dit altijd het geval.
|
|
// Als er nog nooit is geinspecteerd en er is er nog geen ingepland dan is het ook ok.
|
|
// Als de inspectie gestart of gereed gemeld is dan is het ook ok, want anders had de inspectie nooit begonnen mogen worden.
|
|
+ " , CASE"
|
|
+ " WHEN insp.isc_mode = 1"
|
|
+ " THEN 1"
|
|
+ " WHEN (insp.ins_deelsrtcontrole_status IS NULL AND 1 = " + (hasInspect? 0 : 1) + ") OR" // Er is nog nooit geinspecteerd en er is er geen ingepland.
|
|
+ " insp.ins_deelsrtcontrole_status = 2 OR"
|
|
+ " insp.ins_deelsrtcontrole_status = 5"
|
|
+ " THEN 1"
|
|
+ " WHEN insp.ins_deelsrtcontrole_status = 6 AND" // insp.isc_mode = 0 want anders is de vorige when geldig.
|
|
+ " SYSDATE >= CASE insp.eenheid"
|
|
+ " WHEN 0"
|
|
+ " THEN TRUNC (insp.inspectie_next, 'HH')"
|
|
+ " ELSE TRUNC (insp.inspectie_next, 'DD')"
|
|
+ " END"
|
|
+ " THEN 1"
|
|
+ " WHEN insp.ins_deelsrtcontrole_status = 0 AND"
|
|
+ " SYSDATE >= COALESCE (CASE insp.eenheid" // insp.isc_mode = 0 want anders is de vorige when geldig.
|
|
+ " WHEN 0"
|
|
+ " THEN TRUNC (insp.plandatum, 'HH')"
|
|
+ " ELSE TRUNC (insp.plandatum, 'DD') END"
|
|
+ " , CASE insp.eenheid"
|
|
+ " WHEN 0"
|
|
+ " THEN TRUNC (insp.inspectie_next, 'HH')"
|
|
+ " ELSE TRUNC (insp.inspectie_next, 'DD')"
|
|
+ " END)"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END invoerAfterNext"
|
|
// Bepaling in welk jaar er een inspectie is gepland.
|
|
// 1) In het jaar van de plandatum.
|
|
// 2) In het jaar van de startdatum.
|
|
// 3) a) Laatste inspectie is NULL (eerste inspectie moet nog komen) en het is een Controle(1).
|
|
// Volgende inspectie is in het freeze jaar.
|
|
// b) Laatste inspectie is NULL (eerste inspectie moet nog komen) en het is een Vervanging(2) of Certificering(3).
|
|
// Nextdate is na het freeze jaar?
|
|
// Ja) Vorige inspectie ligt na het start jaar en ligt niet in het aanmaak jaar?
|
|
// Ja) Volgende inspectie is in het freeze jaar.
|
|
// Nee) Volgende inspectie is het jaar van de nextdate.
|
|
// Nee) De laatst ingeplande inspectie (nextdate) is na of in het start jaar?
|
|
// Ja) Volgende inspectie is in het freeze jaar.
|
|
// Nee) Volgende inspectie is in het jaar "nextdatum + periode".
|
|
// c) Laatste inspectie is niet NULL. Er is al 1 of meerdere keren geinspecteerd.
|
|
// Ligt de laatst ingeplande inspectie (nextdate) na dit jaar?
|
|
// Ja) Volgende inspectie is het jaar van de nextdate (in de toekomst).
|
|
// Nee) Volgende inspectie is in het freeze jaar.
|
|
+ " , CASE"
|
|
+ " WHEN"
|
|
+ " EXTRACT(YEAR FROM "
|
|
+ " COALESCE(insp.plandatum"
|
|
+ " , CASE WHEN insp.laatste IS NULL THEN insp.ins_srtcontroledl_xcp_startdat ELSE NULL END"
|
|
+ " , CASE"
|
|
+ " WHEN insp.laatste IS NULL AND insp.ctr_controle_type = 1" // 1: Controle.
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " WHEN insp.laatste IS NULL AND insp.ctr_controle_type != 1" // 2: Vervanging, 3: Certificering.
|
|
+ " THEN" // Er is nog geen inspectie geweest
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM insp.inspectie_next0) > " + mjb_freeze_year
|
|
+ " THEN" // Nextdate is na de freeze datum.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM ADD_MONTHS(insp.inspectie_next0, -1 * 12 * insp.ins_srtcontrole_periode)) >= " + mjb_start_year + " AND"
|
|
+ " EXTRACT(YEAR FROM ADD_MONTHS(insp.inspectie_next0, -1 * 12 * insp.ins_srtcontrole_periode)) != EXTRACT(YEAR FROM insp.ins_deel_aanmaak)"
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Vorige inspectie ligt tussen start en freeze jaar (Nu ligt er ook tussen).
|
|
+ " ELSE insp.inspectie_next0"
|
|
+ " END"
|
|
+ " ELSE" // Nextdate is voor of in het freeze jaar.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM insp.inspectie_next0) >= " + mjb_start_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Nextdate tussen start en freeze jaar.
|
|
+ " ELSE ADD_MONTHS(insp.inspectie_next0, 12 * insp.ins_srtcontrole_periode)" // Nextdate voor het start jaar.
|
|
+ " END"
|
|
+ " END"
|
|
+ " ELSE" // Laatste IS NOT NULL. Er is al een inspectie geweest.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM insp.inspectie_next0) > EXTRACT(YEAR FROM SYSDATE)"
|
|
+ " THEN insp.inspectie_next0" // Volgende inspectie is in de toekomst.
|
|
+ " ELSE TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Laatst ingeplande inspectie is nog niet uitgevoerd.
|
|
+ " END"
|
|
+ " END)) = " + mjb_freeze_year
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END isFreezeYear"
|
|
+ " FROM ("
|
|
// De view ins_v_defined_inspect_xcp levert de volgende regels op
|
|
// Alle Active Situatie (AS) soort controle's die geen uitzondering (XCP) record hebben maar wel een scenario.
|
|
// en
|
|
// Alle Active Situatie (AS) soort controle's die:
|
|
// a) geen uitzondering (XCP) record hebben en geen scenario.
|
|
// b) een uitzondering (XCP) record hebben.
|
|
// Hier niet van belang: Alle soort controles van de scenario's (AND xcp.ins_scenario_key = 1).
|
|
+ " SELECT idsc.ins_deelsrtcontrole_key"
|
|
+ " , idsc.ins_deelsrtcontrole_datum"
|
|
+ " , idsc.ins_deelsrtcontrole_status"
|
|
+ " , xcp.ins_srtcontroledl_xcp_eind vervaldatum"
|
|
+ " , xcp.ins_srtcontrole_mode isc_mode"
|
|
+ " , xcp.ins_srtcontrole_options options"
|
|
+ " , xcp.ins_srtcontrole_eenheid eenheid"
|
|
+ " , xcp.ins_srtcontrole_periode"
|
|
+ " , xcp.ins_deel_aanmaak"
|
|
+ " , xcp.ctr_controle_type"
|
|
+ " , idsc.ins_deelsrtcontrole_plandatum plandatum"
|
|
+ " , ins_srtcontroledl_xcp_startdat"
|
|
+ " , CASE"
|
|
+ " WHEN 1 = " + (hasInspect? 0 : 1) // lastinspect IS NULL
|
|
+ " THEN (SELECT d.ins_deel_aanmaak FROM ins_deel d WHERE d.ins_deel_key = " + pins_deel_key + ")"
|
|
+ " WHEN idsc.ins_deelsrtcontrole_status IN (0, 2)"
|
|
+ " THEN ins_deelsrtcontrole_datum_org"
|
|
+ " ELSE fac.nextcyclusdate(CASE"
|
|
+ " WHEN xcp.ins_srtcontrole_mode = 0"
|
|
+ " THEN idsc.ins_deelsrtcontrole_datum_org" // Moment modus (0). Uitgaan van eigenlijke/orginele inspectiedatum.
|
|
+ " ELSE idsc.ins_deelsrtcontrole_datum" // Interval modus (1). Uitgaan van werkelijke inspectiedatum.
|
|
+ " END"
|
|
+ " , xcp.ins_srtcontrole_mode"
|
|
+ " , xcp.ins_srtcontrole_eenheid"
|
|
+ " , xcp.ins_srtcontrole_periode"
|
|
+ " , xcp.ins_srtcontrole_bits"
|
|
+ " , 1"
|
|
+ " , xcp.ctr_ismjob)"
|
|
+ " END inspectie_next"
|
|
+ " , ins.nextcyclusdate(xcp.ins_deel_key, xcp.ins_srtcontrole_key, 1, 0) inspectie_next0"
|
|
+ " , (SELECT MAX(idsc2.ins_deelsrtcontrole_datum)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = " + pins_deel_key
|
|
+ " AND idsc2.ins_srtcontrole_key = " + params.srtcont_key
|
|
+ " AND idsc2.ins_scenario_key = 1) laatste"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " , ins_v_defined_inspect_xcp xcp"
|
|
+ " WHERE xcp.ins_srtcontrole_key = idsc.ins_srtcontrole_key(+)" // Er kan nog voor de eerste keer geinspecteerd moeten worden.
|
|
+ " AND xcp.ins_srtcontrole_key = " + params.srtcont_key
|
|
+ " AND xcp.ins_deel_key = " + pins_deel_key
|
|
+ " AND idsc.ins_deel_key(+) = " + pins_deel_key
|
|
+ " AND idsc.ins_scenario_key(+) = " + params.scen_key
|
|
// Neem voor de rechten de xcp van de Active Situatie (AS). Die bepaalt of de soort controle vervallen is.
|
|
+ " AND xcp.ins_scenario_key = 1"
|
|
+ (params.deelsrtcont_key > 0
|
|
? " AND idsc.ins_deelsrtcontrole_key = " + params.deelsrtcont_key
|
|
: " AND (idsc.ins_deelsrtcontrole_key IS NULL OR"
|
|
+ " idsc.ins_deelsrtcontrole_key = (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = " + pins_deel_key
|
|
+ " AND idsc2.ins_srtcontrole_key = " + params.srtcont_key
|
|
+ " AND idsc2.ins_scenario_key = " + params.scen_key
|
|
+ " ))")
|
|
+ " ) insp"
|
|
+ " ORDER BY insp.ins_deelsrtcontrole_datum DESC";
|
|
var oRs = Oracle.Execute(sql);
|
|
// Waarden moeten aanwezig zijn. Mocht dat niet zo zijn dan is er iets fout.
|
|
// Als er nog nooit een inspectie is geweest wordt de status -1.
|
|
// Als de laatste inspectie is afgerond (stutus is 6) moet er een nieuwe inspectie gestart worden.
|
|
ins_deelsrtcontrole_status = oRs("ins_deelsrtcontrole_status").Value != null? oRs("ins_deelsrtcontrole_status").Value : -1;
|
|
vervaldatum = oRs("vervaldatum").Value != null? new Date(oRs("vervaldatum").Value) : null;
|
|
isc_options = oRs("options").Value;
|
|
vervallen = vervaldatum != null && vervaldatum < new Date();
|
|
invoerAfterNext = oRs("invoerAfterNext").Value == 1;
|
|
isFreezeYear = oRs("isFreezeYear").Value == 1;
|
|
oRs.Close();
|
|
}
|
|
|
|
iresult.invoerAfterNext = invoerAfterNext;
|
|
|
|
// Voor CTR alleen discipline autorisatie met 3D ja/nee en read/write autorisatie (fac_functie_min_level = 3)
|
|
ctrresult = user.func_enabled("CTR",
|
|
ctr_discipline_key,
|
|
null, // alg_key is nvt
|
|
null, // prs_key in nvt
|
|
false, // pessimist (checkOptimistic)
|
|
true); // nog even optional (isOptional)
|
|
|
|
iresult.hasCTRRead = ctrresult.canRead("WEB_CTRUSE"); // Heb ik lees rechten om periodieke taken te zien?
|
|
iresult.hasCTRWrite = ctrresult.canWrite("WEB_CTRUSE") || objectbeheerder;// Heb ik schrijf rechten om periodieke taken uit te voeren?
|
|
|
|
iresult.canShowXcp = iresult.hasCTRRead && iresult.canRead("WEB_INSMAN"); // Exceptions (xcp) waarden inspecties/taken bekijken (waarden in ins_srtcontroledl_xcp tabel).
|
|
iresult.canChangeXcp = iresult.hasCTRWrite && iresult.canWrite("WEB_INSMAN"); // Exceptions (xcp) waarden inspecties/taken wijzigen (waarden in ins_srtcontroledl_xcp tabel).
|
|
iresult.canAddToScen = iresult.canChangeXcp && ins_deelsrtcontrole_status != 2 && ins_deelsrtcontrole_status != 5;
|
|
|
|
// Op een scenario kun je geen inspecties doen. Je kunt alleen inplannen en een planning wijzigen. Verder geen inspectie rechten.
|
|
var isScenario = params.scen_key > 1;
|
|
// Een nieuwe inspectie mag pas weer aangemaakt worden als de laatste inspectie Afgerond(6) is.
|
|
// Als de inspectie vervallen is moet je alleen nog de lopende inspecties (ingepland of later) kunnen gereedmelden en/of afronden,
|
|
// zodat deze inspectie afgerond kan worden. Nieuwe inspectie kunnen nooit meer beginnen.
|
|
// Eerste inspectie of verwerkte inspectie kan niet gewijzigd worden.
|
|
iresult.canMsuEdit = periode > 0 && iresult.writemsu && ins_deelsrtcontrole_status == 6 && !isScenario;
|
|
iresult.canInspEdit = periode > 0 &&
|
|
((iresult.readuse && ins_deelsrtcontrole_status != -1 && ins_deelsrtcontrole_status != 6) ||
|
|
iresult.canMsuEdit) &&
|
|
!vervallen && actief && iresult.hasCTRWrite;
|
|
iresult.canInspShow = periode > 0 && iresult.readuse && !vervallen && (ins_deelsrtcontrole_status >= 0) &&
|
|
iresult.hasCTRRead && !isScenario;
|
|
// Bij eerste inspectie of verwerkte inspectie kan er gepland worden.
|
|
iresult.canInspPlanReq = periode > 0 && iresult.readuse && !vervallen &&
|
|
(ins_deelsrtcontrole_status == -1 || ins_deelsrtcontrole_status == 6) &&
|
|
actief && iresult.hasCTRWrite &&
|
|
((isc_options & 1) == 1);
|
|
iresult.canInspPlan = iresult.canInspPlanReq && !ctr_ismjob;
|
|
iresult.canInspPlanMjb = iresult.canInspPlanReq && ctr_ismjob;
|
|
// Bij eerste inspectie, geplande inspectie of verwerkte inspectie kan er gestart worden.
|
|
iresult.canInspStartReq = periode > 0 && iresult.readuse && invoerAfterNext && !vervallen &&
|
|
(ins_deelsrtcontrole_status <= 0 || ins_deelsrtcontrole_status == 6) &&
|
|
actief && iresult.hasCTRWrite &&
|
|
((isc_options & 2) == 2) &&
|
|
!isScenario;
|
|
iresult.canInspStart = iresult.canInspStartReq && !ctr_ismjob;
|
|
// Bevriezen gebeurt altijd voor het kalenderjaar S("mjb_freeze_year").
|
|
// Dan is er voor het freeze kalenderjaar een bedrag ingevuld.
|
|
// Mocht het bedrag 0 zijn, dan moet er tijdens heb bevriezen een lcl aan de opmerking worden toegevoegd, dat de taak door een hogere prio taak wordt uitgevoerd.
|
|
iresult.canInspFreeze = iresult.canInspStartReq && isFreezeYear;
|
|
// Bij eerste inspectie, geplande inspectie, gestarte inspectie of verwerkte inspectie kan er gereedgemeld/afgerond worden.
|
|
iresult.canInspClose = periode > 0 && iresult.readuse && invoerAfterNext &&
|
|
((!vervallen && (ins_deelsrtcontrole_status < 5 || ins_deelsrtcontrole_status == 6)) ||
|
|
(ins_deelsrtcontrole_status == 0 || ins_deelsrtcontrole_status == 2)) &&
|
|
actief && iresult.hasCTRWrite &&
|
|
((isc_options & 4) == 4) &&
|
|
!isScenario && !ctr_ismjob;
|
|
// Afronden kan vanuit elke status. Alleen vanuit status Gereed gemeld/Afgemeld(5) kan het zonder gegevens in te vullen.
|
|
iresult.canInspFinishReq = periode > 0 && iresult.readuse && invoerAfterNext &&
|
|
actief && iresult.hasCTRWrite &&
|
|
((isc_options & 8) == 8) &&
|
|
!isScenario;
|
|
iresult.canInspFinish = iresult.canInspFinishReq && !ctr_ismjob;
|
|
iresult.canInspFinishMjb = iresult.canInspFinishReq && ins_deelsrtcontrole_status == 2 && ctr_ismjob;
|
|
// Alleen als de inspectie gereedgemeld is kan SNEL afgerond worden zonder gegevens in te vullen.
|
|
iresult.canInspFastFinish = periode > 0 && iresult.canInspFinish && ins_deelsrtcontrole_status == 5;
|
|
}
|
|
else
|
|
{
|
|
iresult.invoerAfterNext = true;
|
|
|
|
// Zijn er soort controles waar de user lees of schrijf rechten op heeft?
|
|
// Eerst lezen.
|
|
var bsql = "SELECT COUNT(*) aantal"
|
|
+ " FROM (SELECT xcp.ins_srtcontrole_key"
|
|
+ " FROM ins_v_defined_inspect_xcp xcp"
|
|
+ " WHERE xcp.ins_deel_key = " + pins_deel_key
|
|
+ " AND xcp.ctr_discipline_key IN (SELECT w.ins_discipline_key" // Alleen van de disciplines waar ik schrijf rechten op heb meetellen.
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_read < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_read < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key + ")"
|
|
+ " GROUP BY xcp.ins_srtcontrole_key"
|
|
+ " , xcp.ins_deel_key)";
|
|
var boRs = Oracle.Execute(bsql);
|
|
var add = boRs("aantal").Value > 0;
|
|
iresult.hasAnyReadXcp = boRs("aantal").Value > 0 && iresult.canRead("WEB_INSMAN"); // Enige rechten om exceptions (xcp) waarden te lezen.
|
|
boRs.close();
|
|
|
|
// Nu schrijven.
|
|
var bsql = "SELECT COUNT(*) aantal"
|
|
+ " FROM (SELECT xcp.ins_srtcontrole_key"
|
|
+ " FROM ins_v_defined_inspect_xcp xcp"
|
|
+ " WHERE xcp.ins_deel_key = " + pins_deel_key
|
|
+ " AND xcp.ctr_discipline_key IN (SELECT w.ins_discipline_key" // Alleen van de disciplines waar ik schrijf rechten op heb meetellen.
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_write < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_write < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key + ")"
|
|
+ " GROUP BY xcp.ins_srtcontrole_key"
|
|
+ " , xcp.ins_deel_key)";
|
|
var boRs = Oracle.Execute(bsql);
|
|
var add = boRs("aantal").Value > 0;
|
|
iresult.hasAnyWriteXcp = boRs("aantal").Value > 0 && iresult.canWrite("WEB_INSMAN"); // Enige rechten om exceptions (xcp) waarden te schrijven.
|
|
iresult.canDoAnyInspect = boRs("aantal").Value > 0 && iresult.canRead("WEB_INSMAN"); // Enige rechten om inspecties te doen.
|
|
boRs.close();
|
|
}
|
|
}
|
|
ioRs.Close();
|
|
|
|
return iresult;
|
|
},
|
|
|
|
func_enabled_scope: // Wat mag ik zoal op deze specifieke scope?
|
|
// levert null als zelfs nog geen leesrechten
|
|
function (ins_discipline_key, ins_alg_ruimte_type, ins_alg_ruimte_key, params)
|
|
{
|
|
var iresult = {canDelete: false, canChange: false}; // Verwijderen en Wijzigen
|
|
var fronto = params && params.urole? params.urole == "fo" : false;
|
|
if (ins_alg_ruimte_type == "A")
|
|
{
|
|
var afd_key = ins_alg_ruimte_key;
|
|
|
|
iresult = user.func_enabled("INS",
|
|
ins_discipline_key,
|
|
null, // alg_key is nvt
|
|
null, // hier zou alleen een prs_key in mogen, we testen zo afzonderlijk
|
|
false, // pessimist
|
|
true); // nog even optional
|
|
if (!iresult || !iresult.anyfound)
|
|
return null;
|
|
var canWriteINSMAN = prs.canWriteAfdeling(afd_key, "WEB_INSMAN");
|
|
var canWriteINSUSE = prs.canWriteAfdeling(afd_key, "WEB_INSUSE");
|
|
var canWriteINSFOF = prs.canWriteAfdeling(afd_key, "WEB_INSFOF");
|
|
iresult.writeman = canWriteINSMAN;
|
|
iresult.writeuse = canWriteINSUSE;
|
|
iresult.writefof = canWriteINSFOF;
|
|
iresult.canDelete = canWriteINSMAN; // Verwijderen
|
|
iresult.canChange = canWriteINSMAN || canWriteINSUSE; // Wijzigen
|
|
iresult.canChangeAlg = canWriteINSMAN && !fronto; // Wijzigen algemene gegevens
|
|
iresult.canCopy = canWriteINSMAN; // Kopiëren
|
|
}
|
|
else if (ins_alg_ruimte_type == "P" || ins_alg_ruimte_type == "C")
|
|
{
|
|
iresult = user.func_enabled("INS",
|
|
ins_discipline_key,
|
|
null, // alg_key is nvt
|
|
ins_alg_ruimte_key, // prs_key
|
|
false, // pessimist
|
|
true); // nog even optional
|
|
if (!iresult || !iresult.anyfound)
|
|
return null;
|
|
iresult.writeman = iresult.canWrite("WEB_INSMAN");
|
|
iresult.writeuse = iresult.canWrite("WEB_INSUSE");
|
|
iresult.writefof = iresult.canWrite("WEB_INSFOF");
|
|
iresult.canDelete = iresult.canWrite("WEB_INSMAN"); // Verwijderen
|
|
iresult.canChange = iresult.canWrite("WEB_INSMAN") || iresult.canWrite("WEB_INSUSE"); // Wijzigen
|
|
iresult.canChangeAlg = iresult.canWrite("WEB_INSMAN") && !fronto; // Wijzigen algemene gegevens
|
|
iresult.canCopy = iresult.canWrite("WEB_INSMAN"); // Kopiëren
|
|
}
|
|
else
|
|
{
|
|
var alg_ruimte_key = ins_alg_ruimte_key;
|
|
var alg_ruimte_type = ins_alg_ruimte_type;
|
|
|
|
if (alg_ruimte_type == "W")
|
|
{
|
|
var sql = "SELECT w.prs_alg_ruimte_key"
|
|
+ " FROM prs_werkplek w"
|
|
+ " WHERE w.prs_werkplek_key = " + alg_ruimte_key;
|
|
var oRs = Oracle.Execute(sql);
|
|
alg_ruimte_key = oRs("prs_alg_ruimte_key").Value;
|
|
oRs.Close();
|
|
}
|
|
else if (alg_ruimte_type == "T")
|
|
{
|
|
var sql = "SELECT t.alg_locatie_key"
|
|
+ " FROM alg_terreinsector t"
|
|
+ " WHERE t.alg_terreinsector_key = " + alg_ruimte_key;
|
|
var oRs = Oracle.Execute(sql);
|
|
alg_ruimte_key = oRs("alg_locatie_key").Value;
|
|
oRs.Close();
|
|
}
|
|
// Voor alg_ruimte_type = "P" heeft alg_ruimte_key al de juiste waarde
|
|
|
|
iresult = user.func_enabled("INS",
|
|
ins_discipline_key,
|
|
alg_ruimte_key,
|
|
null, // prs_key
|
|
false, // Pessimist.
|
|
true);
|
|
if (!iresult || !iresult.anyfound)
|
|
return null;
|
|
|
|
// Alleen backoffice mag verwijderen, dus "WEB_INSMAN" als autorisatie functie nemen.
|
|
iresult.writeman = iresult.canWrite("WEB_INSMAN");
|
|
iresult.writeuse = iresult.canWrite("WEB_INSUSE");
|
|
iresult.writefof = iresult.canWrite("WEB_INSFOF");
|
|
iresult.canDelete = iresult.canWrite("WEB_INSMAN"); // Verwijderen.
|
|
iresult.canChange = iresult.canWrite("WEB_INSMAN") || iresult.canWrite("WEB_INSUSE"); // Wijzigen.
|
|
iresult.canChangeAlg = iresult.canWrite("WEB_INSMAN") && !fronto; // Wijzigen algemene gegevens.
|
|
iresult.canCopy = iresult.canWrite("WEB_INSMAN"); // Kopiëren.
|
|
}
|
|
// Let op: WEB_INSMSU is niet discipline gebonden en zit dus niet in iresult
|
|
var autparamsINSMSU = user.checkAutorisation("WEB_INSMSU", true);
|
|
iresult.writemsu = autparamsINSMSU && autparamsINSMSU.PRSwritelevel < 9 && autparamsINSMSU.ALGwritelevel < 9; // Wijzigen Afgeronde gegevens.
|
|
iresult.readuse = iresult.canRead("WEB_INSUSE"); // Inzien.
|
|
iresult.readman = iresult.canRead("WEB_INSMAN");
|
|
return iresult;
|
|
},
|
|
|
|
getresdeel_sql:
|
|
function ()
|
|
{
|
|
return " (SELECT res_ins_deel_key,"
|
|
+ " MIN(res_deel_key) res_deel_key,"
|
|
+ " MIN(res_deel_opmerking) res_deel_opmerking,"
|
|
+ " COUNT(*) res_deel_count"
|
|
+ " FROM (SELECT res_deel_key"
|
|
+ " , res_ins_deel_key"
|
|
+ " , " + lcl.xsqla('res_deel_opmerking', 'res_deel_key')
|
|
+ " FROM res_deel"
|
|
+ " WHERE res_deel_verwijder IS NULL"
|
|
+ " AND res_deel_vervaldatum IS NULL"
|
|
+ " UNION ALL"
|
|
+ " SELECT res_deel_key"
|
|
+ " , res_ins_deel_key"
|
|
+ " , " + lcl.xsqla('res_deel_opmerking', 'res_deel_key')
|
|
+ " FROM res_deel"
|
|
+ " WHERE res_deel_verwijder IS NULL"
|
|
+ " AND res_deel_vervaldatum > SYSDATE) "
|
|
+ " GROUP BY res_ins_deel_key)"
|
|
},
|
|
|
|
getobjectinspect_sql:
|
|
function (pautfunction, params)
|
|
{ // Lever de objecten of inpectie sql op.
|
|
var urole = params.urole;
|
|
var fronto = (urole == "fo");
|
|
var backo = (urole == "bo");
|
|
var minfo = (urole == "mi"); // NOT APPLICABLE?
|
|
var frontend = (urole == "fe" || (!fronto && !backo && !minfo));
|
|
|
|
var outputmode = params.outputmode; // print to 0 = screen, 1 = printer, 2 = excel, etc.
|
|
var print = (outputmode == 1 || outputmode == 5);
|
|
var excel = (outputmode == 2 || outputmode == 6);
|
|
var showall = params.showall;
|
|
|
|
var reg_key = params.reg_key;
|
|
var dist_key = params.dist_key;
|
|
var loc_key = params.loc_key;
|
|
var bld_key = params.bld_key;
|
|
var terr_key = params.terr_key; // FGII parameters
|
|
var flr_key = params.flr_key;
|
|
var room_key = params.room_key;
|
|
var wpl_key = params.wpl_key;
|
|
var deel = params.deel;
|
|
var deel_opm = params.deel_opm;
|
|
var disc_key = params.disc_key;
|
|
var insgroup_key = params.insgroup_key;
|
|
var objsrt_key = params.objsrt_key;
|
|
var objsrt_oms = params.objsrt_oms;
|
|
var groep = params.groep;
|
|
var ctrdisc_key = params.ctrdisc_key;
|
|
var dep_key = params.dep_key;
|
|
var persoon_key = params.persoon_key;
|
|
var beh_key = params.beh_key;
|
|
var cpersoon_key = params.cpersoon_key;
|
|
var cnt_bedrijf_key = params.cnt_bedrijf_key;
|
|
var mld_key = params.mld_key;
|
|
var fgraph = params.fgraph; // FGII parameters
|
|
var ins_key_arr = params.ins_key_arr; // FGII parameters
|
|
var parent_key = params.parent_key;
|
|
var koppel_key = params.koppel_key;
|
|
var room_key_arr = params.room_key_arr; // FGII parameters
|
|
var comp_key = params.comp_key; // FGII parameters
|
|
var insObjIncl = params.insObjIncl;
|
|
var expObjIncl = params.expObjIncl;
|
|
var insLentOut = params.insLentOut;
|
|
var insAvail = params.insAvail;
|
|
var insSuccessY = params.insSuccessY;
|
|
var insSuccessN = params.insSuccessN;
|
|
var embedded = params.embedded;
|
|
var tiny = params.tiny || parent_key || koppel_key;
|
|
var srtcontrole = params.srtcontrole;
|
|
var inspsoonfrom = params.inspsoonfrom;
|
|
var inspsoonto = params.inspsoonto;
|
|
var donedatefrom = params.donedatefrom;
|
|
var donedateto = params.donedateto;
|
|
var inspect = params.inspect;
|
|
var mobile = params.mobile;
|
|
var inacObjIncl = params.inacObjIncl;
|
|
var inspClosed = params.inspClosed;
|
|
var inspDone = params.inspDone;
|
|
var inspBusy = params.inspBusy;
|
|
var inspSoon = params.inspSoon;
|
|
var mjob = params.mjob;
|
|
var fitness_score1_from = params.fitness_score1_from;
|
|
var fitness_score1_through = params.fitness_score1_through;
|
|
var gwfitness_score1_from = params.gwfitness_score1_from;
|
|
var gwfitness_score1_through = params.gwfitness_score1_through;
|
|
var priority_score2_from = params.priority_score2_from;
|
|
var priority_score2_through = params.priority_score2_through;
|
|
|
|
var sql_objincl = "";
|
|
if (insObjIncl || parent_key > 0)
|
|
sql_objincl = "";
|
|
else
|
|
sql_objincl += " AND i.ins_deel_parent_key IS NULL ";
|
|
|
|
if (!expObjIncl && ((backo && !deel) || !backo))
|
|
sql_objincl += " AND (i.ins_deel_vervaldatum IS NULL OR i.ins_deel_vervaldatum > TRUNC(SYSDATE)) ";
|
|
|
|
if (!inacObjIncl && ((backo && !deel) || !backo))
|
|
sql_objincl += " AND i.ins_deel_actief = 1 ";
|
|
|
|
var hasPosition = false; // Had the user selected something on the left side of the filter dialog
|
|
var hasOwner = false; // .... or on the right side
|
|
|
|
sql = "";
|
|
sqlOwner = sqlOwnerA = sqlOwnerB = sqlPosition = "";
|
|
|
|
if (ins_key_arr || parent_key)
|
|
{
|
|
hasPosition = true; // we don't need other filters and these objects
|
|
}
|
|
else
|
|
{
|
|
if (reg_key || dist_key || loc_key || bld_key || terr_key || flr_key || wpl_key || room_key || room_key_arr)
|
|
{
|
|
hasPosition = true;
|
|
}
|
|
|
|
if (comp_key || dep_key || persoon_key || cpersoon_key)
|
|
{
|
|
hasOwner = true;
|
|
}
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////
|
|
//
|
|
// Start building the query to fetch all objects satisfying
|
|
// the conditions the user has built with all select boxes
|
|
//
|
|
// We already have set globals
|
|
// sql_objincl SQL-query part to in/exclude sub-objects
|
|
// sql_owner SQL-query part to filter owner(bound) objects
|
|
// filtering on object-discipline etc. will be added after building location/owner
|
|
///////////////////////////////////////////////////////////
|
|
|
|
// not a combined query but either location based or department/person based
|
|
|
|
// PF: deze subquery geeft de *oorspronkelijke* plaats/eigenaar (als tekst)
|
|
// van het object voor het geval dat deze op dit moment uitgeleend is, anders NULL
|
|
// Dit is alleen relevant bij fronto, daar wordt deze herkomst weergegeven.
|
|
|
|
sqlInspectie_select = " NULL";
|
|
sqlInspectie_from = "";
|
|
sqlInspectie_where = "";
|
|
// Voor periodieke inspecties is de scenario key NULL.
|
|
if (fronto)
|
|
{
|
|
sqlLentOutFrom = "CASE WHEN i.ins_alg_ruimte_type_org = 'A'"
|
|
+ " THEN (SELECT " + S("prs_dep_string")
|
|
+ " FROM prs_v_afdeling d"
|
|
+ " WHERE d.prs_afdeling_key = i.ins_alg_ruimte_key_org)"
|
|
+ " WHEN i.ins_alg_ruimte_type_org = 'P'"
|
|
+ " THEN (SELECT " + S("prs_pers_string") // keertje omschrijven naar prs_perslid_naam_full
|
|
+ " FROM prs_perslid p"
|
|
+ " WHERE p.prs_perslid_key = i.ins_alg_ruimte_key_org)"
|
|
+ " WHEN i.ins_alg_ruimte_type_org IN ('R', 'T', 'W')"
|
|
+ " THEN (SELECT o.alg_plaatsaanduiding"
|
|
+ " FROM ins_v_alg_overzicht o"
|
|
+ " WHERE o.alg_onroerendgoed_keys = i.ins_alg_ruimte_key_org"
|
|
+ " AND o.alg_onroerendgoed_type = i.ins_alg_ruimte_type_org)"
|
|
+ " ELSE NULL"
|
|
+ " END";
|
|
}
|
|
else
|
|
{
|
|
sqlLentOutFrom = " NULL";
|
|
// Geeft NULL als geen inspectie nodig
|
|
// Eerstvolgende inspectie moet komen/had moeten komen: COALESCE (ins_deelsrtcontrole_datum, ins_deel_aanmaak) + ins_srtcontrole_periode
|
|
if (inspect)
|
|
{
|
|
var lastinspect = "(SELECT MAX(1)"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " WHERE idsc.ins_srtcontrole_key = di.ins_srtcontrole_key"
|
|
+ " AND idsc.ins_deelsrtcontrole_status IN (5, 6)"
|
|
+ " AND idsc.ins_deel_key = di.ins_deel_key"
|
|
+ " AND idsc.ins_scenario_key = 1)";
|
|
|
|
// Eerstvolgende inspectie
|
|
var sqlNext = "SELECT ins_deel_key"
|
|
+ (inspDone
|
|
? " , inspectie_date"
|
|
: " , inspectie_next")
|
|
+ " , ins_srtcontroledl_xcp_startdat"
|
|
+ " , nonext"
|
|
+ " , inspectie_eenheid"
|
|
+ " , inspectie_eind"
|
|
+ " , ins_srtcontrole_omschrijving"
|
|
+ " , ins_srtcontrole_key"
|
|
+ " , options"
|
|
+ " , ins_deelsrtcontrole_status"
|
|
+ " , ins_deelsrtcontrole_plandatum"
|
|
+ " , ctr_controle_type"
|
|
+ (!mobile
|
|
? " , periode"
|
|
+ " , groepoms"
|
|
+ " , ins_deelsrtcontrole_key"
|
|
+ " , ins_controlemode_success"
|
|
+ " , ctr_disc_key"
|
|
+ " , ctr_disc_oms"
|
|
: "")
|
|
+ " FROM ("
|
|
+ (inspDone
|
|
? " SELECT 1 rn" // Afgehandelde inspecties.
|
|
+ " , di.ins_deel_key"
|
|
+ " , dsc.ins_deelsrtcontrole_datum inspectie_date"
|
|
+ " , di.ins_srtcontroledl_xcp_startdat"
|
|
+ " , NULL nonext"
|
|
+ " , di.ins_srtcontrole_eenheid inspectie_eenheid"
|
|
+ " , di.ins_srtcontrole_eind inspectie_eind"
|
|
+ " , " + lcl.xsqla('di.ins_srtcontrole_omschrijving', 'di.ins_srtcontrole_key')
|
|
+ " , di.ins_srtcontrole_options options"
|
|
+ " , di.ins_srtcontrole_key"
|
|
+ " , -1 ins_deelsrtcontrole_status"
|
|
+ " , NULL ins_deelsrtcontrole_key"
|
|
+ " , (SELECT idsc.ins_deelsrtcontrole_plandatum"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " WHERE idsc.ins_deelsrtcontrole_key = dsc.ins_deelsrtcontrole_key)" // Afgehandelde inspecties.
|
|
+ " ins_deelsrtcontrole_plandatum"
|
|
// Er moet naar de laatste UITGEVOERDE (afgeronde(6)) inspectie gekeken worden om te bepalen of de laatste inspectie een SUCCESS was.
|
|
+ " , di.ctr_controle_type"
|
|
+ " , di.ins_srtcontrole_periode periode"
|
|
+ (!mobile
|
|
? " , di.ins_srtcontrole_groep groepoms"
|
|
+ " , (SELECT cm.ins_controlemode_success"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " , ins_controlemode cm"
|
|
+ " WHERE idsc.ins_controlemode_key = cm.ins_controlemode_key"
|
|
+ " AND idsc.ins_deelsrtcontrole_key = dsc.ins_deelsrtcontrole_key)"
|
|
+ " ins_controlemode_success"
|
|
+ " , di.ctr_discipline_key ctr_disc_key"
|
|
+ " , (SELECT ins_discipline_omschrijving"
|
|
+ " FROM ctr_discipline"
|
|
+ " WHERE ins_discipline_key = di.ctr_discipline_key) ctr_disc_oms"
|
|
: "")
|
|
+ " FROM ins_v_defined_inspect_xcp di"
|
|
+ " , ins_deelsrtcontrole dsc" // Alle inspecties meenemen als het vinkbokje "Afgehandeld" (inspDone) is aangevinkt.
|
|
+ " WHERE di.ins_deel_key = dsc.ins_deel_key"
|
|
+ " AND di.ins_srtcontrole_key = dsc.ins_srtcontrole_key"
|
|
+ " AND di.ins_scenario_key = dsc.ins_scenario_key"
|
|
+ " AND di.ins_scenario_key = 1"
|
|
+ (srtcontrole > -1
|
|
? " AND di.ins_srtcontrole_key = " + srtcontrole
|
|
: "")
|
|
+ (insSuccessY && insSuccessN // Ze kunnen niet beiden false zijn.
|
|
? ""
|
|
: " AND (SELECT cm.ins_controlemode_success"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " , ins_controlemode cm"
|
|
+ " WHERE idsc.ins_controlemode_key = cm.ins_controlemode_key"
|
|
+ " AND idsc.ins_deelsrtcontrole_key = (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = di.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = di.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_deelsrtcontrole_status IN (5, 6)"
|
|
+ " AND idsc2.ins_scenario_key = 1))" + (insSuccessY? " = 1" : " IS NULL"))
|
|
+ " AND di.ctr_discipline_key IN (SELECT w.ins_discipline_key"
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_read < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_read < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key + ")"
|
|
+ " ORDER BY inspectie_date)"
|
|
: (inspSoon || (!inspSoon && !inspBusy && !inspClosed)
|
|
? " SELECT 1 rn" // inspecties die nog nooit zijn uitgevoerd/ingepland. Er is nog geen ins_deelsrtcontrole regel aanwezig en dus ook geen plandatum/respijtdatum.
|
|
+ " , di.ins_deel_key"
|
|
+ " , COALESCE(di.ins_srtcontroledl_xcp_startdat"
|
|
+ " , fac.nextcyclusdate(di.ins_deel_aanmaak"
|
|
+ " , di.ins_srtcontrole_mode"
|
|
+ " , di.ins_srtcontrole_eenheid"
|
|
+ " , di.ins_srtcontrole_periode"
|
|
+ " , di.ins_srtcontrole_bits"
|
|
+ " , 1"
|
|
+ " , di.ctr_ismjob)) inspectie_next"
|
|
+ " , di.ins_srtcontroledl_xcp_startdat"
|
|
+ " , CASE WHEN " + lastinspect + " IS NULL THEN 1 ELSE 0 END nonext"
|
|
+ " , di.ins_srtcontrole_eenheid inspectie_eenheid"
|
|
+ " , di.ins_srtcontrole_eind inspectie_eind"
|
|
+ " , " + lcl.xsqla('di.ins_srtcontrole_omschrijving', 'di.ins_srtcontrole_key')
|
|
+ " , di.ins_srtcontrole_key"
|
|
+ " , di.ins_srtcontrole_options options"
|
|
+ " , -1 ins_deelsrtcontrole_status"
|
|
+ " , NULL ins_deelsrtcontrole_key"
|
|
+ " , NULL ins_deelsrtcontrole_plandatum"
|
|
+ " , di.ctr_controle_type"
|
|
+ " , di.ins_srtcontrole_periode periode"
|
|
+ (!mobile
|
|
? " , di.ins_srtcontrole_groep groepoms"
|
|
+ " , NULL ins_controlemode_success"
|
|
+ " , di.ctr_discipline_key ctr_disc_key"
|
|
+ " , (SELECT ins_discipline_omschrijving"
|
|
+ " FROM ctr_discipline"
|
|
+ " WHERE ins_discipline_key = di.ctr_discipline_key) ctr_disc_oms"
|
|
: "")
|
|
+ " FROM ins_v_defined_inspect_xcp di"
|
|
+ " WHERE (di.ins_deel_key, di.ins_srtcontrole_key) NOT IN"
|
|
+ " (SELECT ins_deel_key, ins_srtcontrole_key"
|
|
+ " FROM ins_deelsrtcontrole)"
|
|
+ " AND di.ins_scenario_key = 1"
|
|
+ (srtcontrole > -1
|
|
? " AND di.ins_srtcontrole_key = " + srtcontrole
|
|
: "")
|
|
+ " AND di.ctr_discipline_key IN (SELECT w.ins_discipline_key"
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_read < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_read < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key + ")"
|
|
+ " UNION ALL"
|
|
: "")
|
|
// Inspecties die al eens zijn uitgevoerd of inspecties die voor het eerst zijn ingepland(0) of gestart(2) maar nog geen uitgevoerde/afgemelde(6) inspectie hebben.
|
|
+ " SELECT RANK ()" // Volgnummertje toekennen
|
|
+ " OVER ("
|
|
+ " PARTITION BY di.ins_deel_key, idsc.ins_srtcontrole_key" // Soort van group-by
|
|
+ " ORDER BY ins_deelsrtcontrole_key DESC) rn" // Op volgorde zetten/Rangschikken/Sorteren op inspectiedatum.
|
|
+ " , di.ins_deel_key"
|
|
+ " , CASE"
|
|
+ " WHEN " + lastinspect + " IS NULL" // Inspectie die voor het eerst is ingepland(0) of gestart(2) maar nog geen uitgevoerde/afgemelde(6) inspectie heeft.
|
|
+ " THEN COALESCE(di.ins_srtcontroledl_xcp_startdat"
|
|
+ " , fac.nextcyclusdate(di.ins_deel_aanmaak" // Dan registratiedatum + planning
|
|
+ " , di.ins_srtcontrole_mode"
|
|
+ " , di.ins_srtcontrole_eenheid"
|
|
+ " , di.ins_srtcontrole_periode"
|
|
+ " , di.ins_srtcontrole_bits"
|
|
+ " , 1"
|
|
+ " , di.ctr_ismjob))"
|
|
+ " WHEN idsc.ins_deelsrtcontrole_status IN (0, 2)"
|
|
+ " THEN ins_deelsrtcontrole_datum_org" // In status 0 en 2 wordt de volgende inspectie in ins_deelsrtcontrole_datum_org direct opgeslagen.
|
|
+ " ELSE"
|
|
+ " fac.nextcyclusdate(CASE"
|
|
+ " WHEN di.ins_srtcontrole_mode = 0"
|
|
+ " THEN idsc.ins_deelsrtcontrole_datum_org" // Moment modus (0). Uitgaan van eigenlijke/orginele inspectiedatum.
|
|
+ " ELSE idsc.ins_deelsrtcontrole_datum" // Interval modus (1). Uitgaan van werkelijke inspectiedatum.
|
|
+ " END"
|
|
+ " , di.ins_srtcontrole_mode"
|
|
+ " , di.ins_srtcontrole_eenheid"
|
|
+ " , di.ins_srtcontrole_periode"
|
|
+ " , di.ins_srtcontrole_bits"
|
|
+ " , 1"
|
|
+ " , di.ctr_ismjob)"
|
|
+ " END inspectie_next"
|
|
+ " , ins_srtcontroledl_xcp_startdat"
|
|
+ " , CASE WHEN " + lastinspect + " IS NULL THEN 1 ELSE 0 END nonext"
|
|
+ " , di.ins_srtcontrole_eenheid inspectie_eenheid"
|
|
+ " , di.ins_srtcontrole_eind inspectie_eind"
|
|
+ " , " + lcl.xsqla('di.ins_srtcontrole_omschrijving', 'di.ins_srtcontrole_key')
|
|
+ " , di.ins_srtcontrole_key"
|
|
+ " , di.ins_srtcontrole_options options"
|
|
+ " , idsc.ins_deelsrtcontrole_status"
|
|
+ " , idsc.ins_deelsrtcontrole_key"
|
|
+ " , CASE"
|
|
+ " WHEN idsc.ins_deelsrtcontrole_status IN (0, 2)"
|
|
+ " THEN idsc.ins_deelsrtcontrole_plandatum"
|
|
+ " ELSE NULL"
|
|
+ " END ins_deelsrtcontrole_plandatum"
|
|
+ " , di.ctr_controle_type"
|
|
+ " , di.ins_srtcontrole_periode periode"
|
|
+ (!mobile
|
|
? " , di.ins_srtcontrole_groep groepoms"
|
|
+ " , NULL ins_controlemode_success"
|
|
+ " , di.ctr_discipline_key ctr_disc_key"
|
|
+ " , (SELECT ins_discipline_omschrijving"
|
|
+ " FROM ctr_discipline"
|
|
+ " WHERE ins_discipline_key = di.ctr_discipline_key) ctr_disc_oms"
|
|
: "")
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " , ins_v_defined_inspect_xcp di"
|
|
+ " , ins_controlemode cm"
|
|
+ " WHERE idsc.ins_controlemode_key = cm.ins_controlemode_key(+)"
|
|
+ " AND idsc.ins_srtcontrole_key = di.ins_srtcontrole_key"
|
|
+ " AND idsc.ins_deel_key = di.ins_deel_key"
|
|
+ " AND idsc.ins_scenario_key = 1"
|
|
+ " AND di.ins_scenario_key = 1"
|
|
+ (srtcontrole > -1
|
|
? " AND di.ins_srtcontrole_key = " + srtcontrole
|
|
: "")
|
|
+ " AND di.ctr_discipline_key IN (SELECT w.ins_discipline_key"
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_read < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_read < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key + ")"
|
|
+ " ORDER BY inspectie_next)")
|
|
+ " WHERE rn = 1"
|
|
// Voor afgehandelde inspecties ook inspecties met periode 0 tonen.
|
|
+ (!inspDone
|
|
? " AND periode > 0"
|
|
: "")
|
|
// Alleen bij "Afgehandeld" vervallen inspecties tonen.
|
|
// Indien vervallen maar nog niet afgerond dan ook de inspectie tonen (status = 0,2 altijd tonen).
|
|
+ (inspBusy || inspClosed || inspSoon
|
|
? " AND (inspectie_eind IS NULL OR inspectie_eind > SYSDATE OR ins_deelsrtcontrole_status = 0 OR ins_deelsrtcontrole_status = 2)"
|
|
: "");
|
|
|
|
sqlInspectie_select = (inspDone? "inspectie_date" : "inspectie_next")
|
|
+ " , ispn.ins_srtcontroledl_xcp_startdat"
|
|
+ " , ispn.ins_srtcontrole_omschrijving"
|
|
+ " , ispn.ins_srtcontrole_key"
|
|
+ " , ispn.options"
|
|
+ " , ispn.ins_deelsrtcontrole_status"
|
|
+ " , ispn.ins_deelsrtcontrole_plandatum"
|
|
+ " , ispn.inspectie_eind"
|
|
+ " , ispn.inspectie_eenheid"
|
|
+ " , ispn.nonext"
|
|
+ " , ispn.ctr_controle_type"
|
|
+ (!mobile
|
|
? " , ispn.groepoms"
|
|
+ " , ispn.ins_deelsrtcontrole_key"
|
|
+ " , ispn.ins_controlemode_success"
|
|
+ " , ispn.ctr_disc_key"
|
|
+ " , ispn.ctr_disc_oms"
|
|
: "");
|
|
|
|
sqlInspectie_from = ", (" + sqlNext + ") ispn"
|
|
|
|
sqlInspectie_where = " AND ispn.ins_deel_key = i.ins_deel_key";
|
|
}
|
|
}
|
|
|
|
if (fronto)
|
|
{
|
|
var sqlKenmerkBewerkbaar_select = ", CASE WHEN k.km900>0 THEN 1 ELSE 0 END bewerkbaar";
|
|
var sqlKenmerkBewerkbaar_from = "( SELECT sd.ins_srtdeel_key"
|
|
+ " , COUNT (km.ins_kenmerk_volgnummer) km900"
|
|
+ " FROM ins_srtkenmerk sk"
|
|
+ " , ins_kenmerk km"
|
|
+ " , ins_srtdeel sd"
|
|
+ " , ins_srtgroep gr"
|
|
+ " WHERE km.ins_srtkenmerk_key = sk.ins_srtkenmerk_key"
|
|
+ " AND gr.ins_srtgroep_key = sd.ins_srtgroep_key"
|
|
+ " AND km.ins_kenmerk_verwijder IS NULL"
|
|
+ " AND sk.ins_srtkenmerk_verwijder IS NULL"
|
|
+ " AND ( ( km.ins_srtinstallatie_key = sd.ins_srtdeel_key"
|
|
+ " AND km.ins_kenmerk_niveau = 'S')"
|
|
+ " OR ( km.ins_srtinstallatie_key = sd.ins_srtgroep_key"
|
|
+ " AND km.ins_kenmerk_niveau = 'G')"
|
|
+ " OR ( km.ins_srtinstallatie_key = gr.ins_discipline_key"
|
|
+ " AND km.ins_kenmerk_niveau = 'D'))"
|
|
+ " AND km.ins_kenmerk_volgnummer >= 900"
|
|
+ "GROUP BY sd.ins_srtdeel_key) k";
|
|
var sqlKenmerkBewerkbaar_where = " AND i.ins_srtdeel_key = k.ins_srtdeel_key(+)";
|
|
}
|
|
else // Dan doen we er toch niets mee
|
|
{
|
|
sqlKenmerkBewerkbaar_select = ", 0 bewerkbaar";
|
|
sqlKenmerkBewerkbaar_from = "DUAL";
|
|
sqlKenmerkBewerkbaar_where = "";
|
|
}
|
|
|
|
sqlReservering_from = "( SELECT rrd.res_rsv_deel_key"
|
|
+ " , rrd.res_rsv_deel_van"
|
|
+ " , rrd.res_rsv_deel_tot"
|
|
+ " FROM res_rsv_deel rrd"
|
|
+ " WHERE rrd.res_rsv_deel_afgemeld IS NULL"
|
|
+ ") rs";
|
|
sqlReservering_where = " AND rs.res_rsv_deel_key(+) = i.res_rsv_deel_key";
|
|
|
|
|
|
// Setting ins_auth_obj_lendout: Authorization scope for objects which are lended out {0=owner(borrower) (default) | 1=basic place/owner}
|
|
//
|
|
// Voor UITGELEENDE objecten geldt: ins_alg_ruimte_type = 'P' en ins_alg_ruimte_type_org IN ('A', 'P', 'C', 'T', 'R', 'W')
|
|
// 0=owner(borrower): De feitelijke eigenaar wordt als de normale eigenaar beschouwd (lener = eigenaar) => autorisatie op ins_alg_ruimte_key.
|
|
// 1=basic place/owner: De oorsprokelijke plaats/eigenaar wordt als de normale plaats/eigenaar beschouwd => autorisatie op ins_alg_ruimte_key_org.
|
|
//
|
|
// Voor NIET UITGELEENDE objecten is er geen verschil => ins_alg_ruimte_type IN ('A', 'P', 'C', 'T', 'R', 'W') en ins_alg_ruimte_type_org IS NULL
|
|
// altijd autorisatie op ins_alg_ruimte_key.
|
|
//
|
|
// Autorisatie op de basis plaats/eigenaar (ins_alg_ruimte_key_org) toepassen.
|
|
// Alleen 1) als de Setting ins_auth_obj_lendout = 1.
|
|
// 2) bij uitleenregistratie (fronto).
|
|
// 3) als het object is uitgeleend (insLentOut).
|
|
var auth_org = S("ins_auth_obj_lendout") == 1 && fronto && insLentOut;
|
|
if (!hasPosition || fronto)
|
|
{ // Position filter would imply only place-objects
|
|
sqlOwner_select = "SELECT TO_CHAR(NULL) plaats"
|
|
+ ", " + lcl.xsql('s.ins_srtdeel_omschrijving', 's.ins_srtdeel_key')+" soort"
|
|
+ ", i.ins_deel_omschrijving"
|
|
+ ", (SELECT ins_discipline_omschrijving"
|
|
+ " FROM ins_discipline idc"
|
|
+ " WHERE i.ins_discipline_key = idc.ins_discipline_key) ins_disc_oms"
|
|
+ ", (SELECT ins_srtgroep_omschrijving"
|
|
+ " FROM ins_srtgroep idc"
|
|
+ " WHERE s.ins_srtgroep_key = idc.ins_srtgroep_key) ins_groep_oms"
|
|
+ ", i.ins_deel_key"
|
|
+ ", i.ins_alg_ruimte_type"
|
|
+ ", i.res_rsv_deel_key" // gereserveerde object
|
|
+ ", rs.res_rsv_deel_van"
|
|
+ ", rs.res_rsv_deel_tot"
|
|
+ ", " + sqlInspectie_select
|
|
+ (!mobile
|
|
? ", s.ins_srtdeel_code"
|
|
+ ", i.ins_deel_opmerking"
|
|
+ ", i.ins_deel_aantal"
|
|
+ ", s.ins_srtdeel_eenheid"
|
|
+ ", s.ins_srtdeel_key"
|
|
+ ", s.ins_srtdeel_upper"
|
|
+ ", i.ins_deel_getekend"
|
|
+ ", i.ins_discipline_key"
|
|
+ ", -1 district"
|
|
+ ", i.ins_deel_x" // is coordinaat bekend?
|
|
+ ", i.ins_deel_y"
|
|
+ ", i.ins_deel_dwgx" // is dwg coordinaat bekend?
|
|
+ ", i.ins_deel_dwgy"
|
|
+ ", ins_srtgroep_key"
|
|
+ ", ins_deel_upper"
|
|
+ ", s.ins_srtdeel_uitleenbaar"
|
|
+ ", i.ins_alg_ruimte_key_org"
|
|
+ ", i.ins_alg_ruimte_type_org"
|
|
+ ", " + sqlLentOutFrom + " uitgegeven_vanuit"
|
|
+ ", rd.res_deel_key"
|
|
+ ", rd.res_deel_opmerking"
|
|
+ ", rd.res_deel_count"
|
|
+ ", (SELECT prs_perslid_naam_full FROM prs_v_perslid_fullnames_all WHERE prs_perslid_key = prs_perslid_key_beh) perslid_beh"
|
|
+ ", i.ins_deel_aanmaak"
|
|
+ ", i.ins_deel_vervaldatum"
|
|
+ ", i.ins_deel_actief"
|
|
+ ", i.ins_deel_mjb_score1"
|
|
+ ", i.ins_deel_mjb_score2"
|
|
+ ", s.ins_srtdeel_mjb_grensscore1"
|
|
: "");
|
|
|
|
sqlOwner_from = " FROM ins_deel i"
|
|
+ ", ins_srtdeel s"
|
|
+ sqlInspectie_from
|
|
+ ", " + ins.getresdeel_sql() + " rd"
|
|
+ ", " + sqlReservering_from;
|
|
|
|
sqlOwner_where = " WHERE s.ins_srtdeel_key = i.ins_srtdeel_key"
|
|
+ " AND i.ins_deel_verwijder IS NULL"
|
|
+ " AND i.ins_deel_key = rd.res_ins_deel_key(+)"
|
|
+ " AND i.ins_deel_module = 'INS'"
|
|
+ " AND s.ins_srtgroep_key NOT IN (" + S("sle_ins_srt_groep_key") + ", " + S("cil_ins_srt_groep_key") + ")"
|
|
+ sql_objincl
|
|
+ sqlInspectie_where
|
|
+ sqlReservering_where
|
|
+ (fronto
|
|
? " AND s.ins_srtdeel_uitleenbaar = 1"
|
|
: "")
|
|
+ (koppel_key
|
|
? " AND idk.ins_deelkoppeling_verwijder IS NULL"
|
|
+ " AND (( i.ins_deel_key = idk.ins_deelkoppeling_naar_key"
|
|
+ " AND idk.ins_deelkoppeling_van_key=" + koppel_key
|
|
+ " )"
|
|
+ " OR ( i.ins_deel_key = idk.ins_deelkoppeling_van_key"
|
|
+ " AND idk.ins_deelkoppeling_naar_key=" + koppel_key + "))"
|
|
: "")
|
|
+ ((insLentOut && !insAvail)
|
|
? " AND i.ins_alg_ruimte_key_org IS NOT NULL"
|
|
: (!insLentOut && insAvail)
|
|
? " AND i.ins_alg_ruimte_key_org IS NULL"
|
|
: "");
|
|
|
|
if (loc_key|| bld_key)
|
|
{
|
|
sqlOwner_from += ", (SELECT alg_ruimte_key"
|
|
+ " FROM alg_v_allonroerendgoed"
|
|
+ " WHERE " + (bld_key ? "alg_gebouw_key" : "alg_locatie_key")
|
|
+ " = " + (bld_key ? bld_key : loc_key)
|
|
+ " ) a";
|
|
sqlOwner_where += " AND i.ins_alg_ruimte_key_org = a.alg_ruimte_key";
|
|
}
|
|
|
|
sqlOwnerA = sqlOwner_select
|
|
+ (!mobile
|
|
? sqlKenmerkBewerkbaar_select
|
|
+ ", b.prs_bedrijf_key prs_bedrijf_key" // bedrijf key
|
|
+ ", d.prs_afdeling_key1"
|
|
+ ", CASE WHEN i.ins_alg_ruimte_type_org IS NOT NULL"
|
|
+ " THEN (SELECT " + S("prs_pers_string") // keertje omschrijven naar prs_perslid_naam_full
|
|
+ " FROM prs_perslid p"
|
|
+ " WHERE p.prs_perslid_key = i.ins_alg_ruimte_key)"
|
|
+ " ELSE (SELECT " + S("prs_dep_string") + " FROM prs_v_afdeling d WHERE prs_afdeling_key = i.ins_alg_ruimte_key)"
|
|
+ " END uitgeleend_aan"
|
|
+ ", NULL alg_ruimte_key " // person key
|
|
+ ", i.ins_alg_ruimte_key prs_afdeling_key" // department key
|
|
+ (koppel_key? ", ins_deelkoppeling_omschrijving, ins_deelkoppeling_van_key, ins_deelkoppeling_naar_key" : "")
|
|
: "")
|
|
+ sqlOwner_from
|
|
+ ", prs_v_afdeling_boom d"
|
|
+ ", prs_bedrijf b"
|
|
+ ", " + sqlKenmerkBewerkbaar_from
|
|
+ (koppel_key? ", ins_deelkoppeling idk" : "")
|
|
+ sqlOwner_where
|
|
+ sqlKenmerkBewerkbaar_where
|
|
+ " AND d.prs_bedrijf_key = b.prs_bedrijf_key";
|
|
|
|
if (auth_org)
|
|
// Object is uitgeleend.
|
|
sqlOwnerA_org = sqlOwnerA
|
|
+ " AND i.ins_alg_ruimte_key_org = d.prs_afdeling_key"
|
|
+ " AND i.ins_alg_ruimte_type_org = 'A'";
|
|
|
|
sqlOwnerA += " AND i.ins_alg_ruimte_key = d.prs_afdeling_key"
|
|
+ " AND i.ins_alg_ruimte_type = 'A'"; // Object is NIET uitgeleend, anders was het type 'P'.
|
|
|
|
|
|
|
|
sqlOwnerP = sqlOwner_select
|
|
+ (!mobile
|
|
? sqlKenmerkBewerkbaar_select
|
|
+ ", b.prs_bedrijf_key prs_bedrijf_key " // bedrijf key
|
|
+ ", d.prs_afdeling_key1"
|
|
+ ", " + S("prs_pers_string") + " uitgeleend_aan" // keertje omschrijven naar prs_perslid_naam_full
|
|
+ ", i.ins_alg_ruimte_key alg_ruimte_key " // person key
|
|
+ ", p.prs_afdeling_key prs_afdeling_key" // department key
|
|
+ (koppel_key? ", ins_deelkoppeling_omschrijving, ins_deelkoppeling_van_key, ins_deelkoppeling_naar_key" : "")
|
|
: "")
|
|
+ sqlOwner_from
|
|
+ ", prs_perslid p"
|
|
+ ", prs_v_afdeling_boom d"
|
|
+ ", prs_bedrijf b"
|
|
+ ", " + sqlKenmerkBewerkbaar_from
|
|
+ (koppel_key? ", ins_deelkoppeling idk" : "")
|
|
+ sqlOwner_where
|
|
+ sqlKenmerkBewerkbaar_where
|
|
+ " AND p.prs_afdeling_key = d.prs_afdeling_key"
|
|
+ " AND d.prs_bedrijf_key = b.prs_bedrijf_key"
|
|
+ " AND i.ins_alg_ruimte_key = p.prs_perslid_key";
|
|
|
|
if (auth_org)
|
|
// Object is uitgeleend.
|
|
sqlOwnerP_org = sqlOwnerP
|
|
+ " AND i.ins_alg_ruimte_type_org = 'P'";
|
|
|
|
sqlOwnerP += " AND i.ins_alg_ruimte_type = 'P'" // Object is wel of niet uitgeleend.
|
|
+ (auth_org
|
|
? " AND i.ins_alg_ruimte_key_org IS NULL" // Dit deel kijkt naar NIET uitgeleende objecten. sqlOwnerA_org naar uitgeleende objecten.
|
|
: "");
|
|
|
|
sqlOwnerCP = sqlOwner_select
|
|
+ (!mobile
|
|
? sqlKenmerkBewerkbaar_select
|
|
+ ", (SELECT c.prs_bedrijf_key FROM prs_contactpersoon c WHERE c.prs_contactpersoon_key = i.ins_alg_ruimte_key) prs_bedrijf_key" // bedrijf key
|
|
+ ", 0 dummy1" // department key
|
|
+ ", c.prs_contactpersoon_naam uitgeleend_aan"
|
|
+ ", i.ins_alg_ruimte_key alg_ruimte_key" // person key
|
|
+ ", NULL prs_afdeling_key" // department key
|
|
+ (koppel_key? ", ins_deelkoppeling_omschrijving, ins_deelkoppeling_van_key, ins_deelkoppeling_naar_key" : "")
|
|
: "")
|
|
+ sqlOwner_from
|
|
+ ", prs_contactpersoon c"
|
|
+ ", prs_bedrijf b"
|
|
+ ", " + sqlKenmerkBewerkbaar_from
|
|
+ (koppel_key? ", ins_deelkoppeling idk" : "")
|
|
+ sqlOwner_where
|
|
+ sqlKenmerkBewerkbaar_where
|
|
+ " AND c.prs_bedrijf_key = b.prs_bedrijf_key"
|
|
+ " AND i.ins_alg_ruimte_key = c.prs_contactpersoon_key";
|
|
|
|
if (auth_org)
|
|
// Object is uitgeleend.
|
|
sqlOwnerCP_org = sqlOwnerCP
|
|
+ " AND i.ins_alg_ruimte_type_org = 'C'";
|
|
|
|
sqlOwnerCP += " AND i.ins_alg_ruimte_type = 'C'"; // Object is NIET uitgeleend, anders was het type 'P'.
|
|
|
|
}
|
|
|
|
if (!hasOwner)
|
|
{ // Owner filter would imply only owned objects
|
|
sqlPosition = "SELECT DISTINCT"
|
|
+ (terr_key
|
|
? " t.alg_terreinsector_omschrijving"
|
|
: " o.alg_plaatsaanduiding"
|
|
+ " || DECODE(o.alg_plaatsomschrijving, '','' ,' (' || o.alg_plaatsomschrijving || ')')"
|
|
)
|
|
+ " plaats"
|
|
+ ", " + lcl.xsql('s.ins_srtdeel_omschrijving', 's.ins_srtdeel_key') + " soort"
|
|
+ ", i.ins_deel_omschrijving"
|
|
+ ", (SELECT ins_discipline_omschrijving"
|
|
+ " FROM ins_discipline idc"
|
|
+ " WHERE i.ins_discipline_key = idc.ins_discipline_key) ins_disc_oms"
|
|
+ ", (SELECT ins_srtgroep_omschrijving"
|
|
+ " FROM ins_srtgroep idc"
|
|
+ " WHERE s.ins_srtgroep_key = idc.ins_srtgroep_key) ins_groep_oms"
|
|
+ ", i.ins_deel_key"
|
|
+ ", i.ins_alg_ruimte_type"
|
|
+ ", i.res_rsv_deel_key" // gereserveerde object
|
|
+ ", rs.res_rsv_deel_van"
|
|
+ ", rs.res_rsv_deel_tot"
|
|
+ ", " + sqlInspectie_select
|
|
+ (!mobile
|
|
? ", s.ins_srtdeel_code"
|
|
+ ", i.ins_deel_opmerking"
|
|
+ ", i.ins_deel_aantal"
|
|
+ ", s.ins_srtdeel_eenheid"
|
|
+ ", s.ins_srtdeel_key"
|
|
+ ", s.ins_srtdeel_upper"
|
|
+ ", i.ins_deel_getekend"
|
|
+ ", i.ins_discipline_key"
|
|
+ ", CASE WHEN i.ins_alg_ruimte_type = 'A' THEN NULL ELSE l.alg_district_key END alg_district_key"
|
|
+ ", i.ins_deel_x" // is coordinaat bekend?
|
|
+ ", i.ins_deel_y"
|
|
+ ", i.ins_deel_dwgx" // is dwg coordinaat bekend?
|
|
+ ", i.ins_deel_dwgy"
|
|
+ ", ins_srtgroep_key" // filtering only
|
|
+ ", ins_deel_upper" // filtering only
|
|
+ ", s.ins_srtdeel_uitleenbaar"
|
|
+ ", i.ins_alg_ruimte_key_org"
|
|
+ ", i.ins_alg_ruimte_type_org"
|
|
+ ", " + sqlLentOutFrom + " uitgegeven_vanuit"
|
|
+ ", rd.res_deel_key"
|
|
+ ", rd.res_deel_opmerking"
|
|
+ ", rd.res_deel_count"
|
|
+ ", (SELECT prs_perslid_naam_full FROM prs_v_perslid_fullnames_all WHERE prs_perslid_key = prs_perslid_key_beh) perslid_beh"
|
|
+ ", i.ins_deel_aanmaak"
|
|
+ ", i.ins_deel_vervaldatum"
|
|
+ ", i.ins_deel_actief"
|
|
+ ", i.ins_deel_mjb_score1"
|
|
+ ", i.ins_deel_mjb_score2"
|
|
+ ", s.ins_srtdeel_mjb_grensscore1"
|
|
+ sqlKenmerkBewerkbaar_select
|
|
+ ", NULL prs_bedrijf_key"
|
|
+ ", NULL prs_afdeling_key1"
|
|
+ ", CASE WHEN i.ins_alg_ruimte_type_org IS NOT NULL"
|
|
+ " THEN (SELECT p.prs_perslid_naam_full"
|
|
+ " FROM prs_v_perslid_fullnames_all p"
|
|
+ " WHERE p.prs_perslid_key = i.ins_alg_ruimte_key)"
|
|
+ " ELSE NULL"
|
|
+ " END uitgeleend_aan"
|
|
+ ", i.ins_alg_ruimte_key alg_ruimte_key"
|
|
+ ", 0 dummy1" // department key
|
|
+ (koppel_key? ", ins_deelkoppeling_omschrijving, ins_deelkoppeling_van_key, ins_deelkoppeling_naar_key" : "")
|
|
: "")
|
|
+ " FROM ins_deel i"
|
|
+ (terr_key
|
|
? ", alg_terreinsector t"
|
|
: ", ins_v_alg_overzicht o")
|
|
+ ", ins_srtdeel s"
|
|
+ sqlInspectie_from
|
|
+ ", alg_locatie l"
|
|
+ ", " + sqlKenmerkBewerkbaar_from
|
|
+ (koppel_key? ", ins_deelkoppeling idk" : "")
|
|
+ ", alg_district di" // I added this for alg_district_key (FSN#1082)
|
|
+ ", " + ins.getresdeel_sql() + " rd"
|
|
+ ", " + sqlReservering_from
|
|
+ " WHERE i.ins_deel_verwijder IS NULL"
|
|
+ " AND i.ins_deel_module = 'INS'"
|
|
+ " AND i.ins_deel_key = rd.res_ins_deel_key(+)"
|
|
+ " AND s.ins_srtgroep_key NOT IN (" + S("sle_ins_srt_groep_key") + ", " + S("cil_ins_srt_groep_key") + ")"
|
|
+ sql_objincl
|
|
+ sqlInspectie_where
|
|
+ sqlKenmerkBewerkbaar_where
|
|
+ " AND l.alg_district_key = di.alg_district_key"
|
|
+ " AND s.ins_srtdeel_key = i.ins_srtdeel_key"
|
|
+ sqlReservering_where
|
|
+ (fronto
|
|
? " AND s.ins_srtdeel_uitleenbaar = 1"
|
|
: "")
|
|
+ ((insLentOut && !insAvail)
|
|
? " AND i.ins_alg_ruimte_key_org IS NOT NULL"
|
|
: (!insLentOut && insAvail)
|
|
? " AND i.ins_alg_ruimte_key_org IS NULL"
|
|
: "");
|
|
|
|
if (!ins_key_arr && !parent_key && !koppel_key)
|
|
{
|
|
if (wpl_key)
|
|
sqlPosition += " AND o.prs_werkplek_key =" + wpl_key;
|
|
else if (room_key_arr)
|
|
//sqlPosition += " AND i.ins_alg_ruimte_key IN (" + room_key_arr.join(",") + ")";
|
|
sqlPosition += " AND ((i.ins_alg_ruimte_key IN (" + room_key_arr.join(",") + ") AND i.ins_alg_ruimte_type='R')"
|
|
+ " OR (i.ins_alg_ruimte_key IN (SELECT prs_werkplek_key FROM prs_werkplek WHERE prs_alg_ruimte_key IN (" + room_key_arr.join(",") + ")) AND i.ins_alg_ruimte_type='W'))";
|
|
else if (room_key)
|
|
sqlPosition += " AND ((i.ins_alg_ruimte_key = " + room_key + " AND i.ins_alg_ruimte_type='R') "
|
|
+ " OR (i.ins_alg_ruimte_key IN (SELECT prs_werkplek_key FROM prs_werkplek WHERE prs_alg_ruimte_key=" + room_key + ") AND i.ins_alg_ruimte_type='W'))";
|
|
else if (flr_key)
|
|
sqlPosition += " AND o.alg_verdieping_key = " + flr_key;
|
|
else if (terr_key)
|
|
sqlPosition += " AND i.ins_alg_ruimte_key IN (" + terr_key + ")";
|
|
else if (bld_key)
|
|
sqlPosition += " AND o.alg_gebouw_key = " + bld_key;
|
|
else if (loc_key)
|
|
sqlPosition += (terr_key
|
|
? " AND t.alg_locatie_key"
|
|
: " AND i.ins_alg_locatie_key")
|
|
+ " = " + loc_key;
|
|
else if (dist_key)
|
|
sqlPosition += " AND di.alg_district_key = " + dist_key;
|
|
else if (reg_key)
|
|
sqlPosition += " AND di.alg_regio_key = " + reg_key;
|
|
else if (!terr_key && fgraph)
|
|
sqlPosition += " AND i.ins_alg_ruimte_key = -1"; // geen terreinen bij fgraph => geen objecten om te laten zien
|
|
}
|
|
|
|
if (ins_key_arr)
|
|
{
|
|
sqlPosition += " AND i.ins_deel_key IN (" + ins_key_arr.join(",") + ")";
|
|
}
|
|
else if (parent_key)
|
|
{
|
|
sqlPosition += " AND i.ins_deel_parent_key IN (" + parent_key + ")";
|
|
}
|
|
else if (koppel_key)
|
|
{
|
|
sqlPosition += " AND idk.ins_deelkoppeling_verwijder IS NULL"
|
|
+ " AND (( i.ins_deel_key = idk.ins_deelkoppeling_naar_key"
|
|
+ " AND idk.ins_deelkoppeling_van_key=" + koppel_key
|
|
+ " )"
|
|
+ " OR ( i.ins_deel_key = idk.ins_deelkoppeling_van_key"
|
|
+ " AND idk.ins_deelkoppeling_naar_key=" + koppel_key + "))";
|
|
}
|
|
|
|
var v_sqlPositionParent = ( params.parent_key
|
|
? " AND ( (i.ins_alg_ruimte_type = 'A' AND o.alg_locatie_key IS NULL)"
|
|
+ " OR (i.ins_alg_ruimte_type <> 'A' AND o.alg_locatie_key = l.alg_locatie_key)"
|
|
+ " )"
|
|
: " AND o.alg_locatie_key = l.alg_locatie_key"
|
|
);
|
|
|
|
if (auth_org)
|
|
// Object is uitgeleend.
|
|
// terr_key is een FGII parameters, dus bij uitlenen nooit gevuld. Gebruik alg_terreinsector_key hoeft niet overwogen te worden zoals hieronder.
|
|
// Object is uitgeleend en i.ins_alg_ruimte_type = 'P'.
|
|
// Eventuele zoekfilters op plaats worden dan ook toegepast op de oorspronkelijke plaats (ins_alg_ruimte_key_org).
|
|
{
|
|
sqlPosition_org = sqlPosition
|
|
+ " AND o.alg_onroerendgoed_keys = i.ins_alg_ruimte_key_org"
|
|
+ " AND o.alg_onroerendgoed_type = i.ins_alg_ruimte_type_org"
|
|
+ " AND i.ins_alg_ruimte_type_org IN ('T','R','W','A')"
|
|
+ v_sqlPositionParent;
|
|
}
|
|
|
|
sqlPosition += (terr_key
|
|
? " AND t.alg_terreinsector_key = i.ins_alg_ruimte_key"
|
|
+ " AND i.ins_alg_ruimte_type = 'T'" // Object is NIET uitgeleend, anders was het type 'P'.
|
|
+ " AND t.alg_locatie_key = l.alg_locatie_key"
|
|
: " AND o.alg_onroerendgoed_keys = i.ins_alg_ruimte_key"
|
|
+ " AND o.alg_onroerendgoed_type = i.ins_alg_ruimte_type"
|
|
+ " AND i.ins_alg_ruimte_type IN ('T','R','W','A')" // Object is NIET uitgeleend, anders was het type 'P'.
|
|
+ v_sqlPositionParent
|
|
);
|
|
}
|
|
|
|
// And some more conditions that apply for both modes (sqlPosition(_org) and hasOwner(_org)):
|
|
var sql_ex = "";
|
|
if (mld_key)
|
|
sql_ex += " AND i.ins_deel_key IN (SELECT ins_deel_key FROM mld_melding_object WHERE mld_melding_key=" + mld_key + ")";
|
|
if (objsrt_key)
|
|
sql_ex += " AND s.ins_srtdeel_key IN (" + objsrt_key.join(",") + ")";
|
|
else if (insgroup_key)
|
|
sql_ex += " AND ins_srtgroep_key = " + insgroup_key;
|
|
else if (disc_key)
|
|
sql_ex += " AND ins_discipline_key IN (" + disc_key + ")";
|
|
|
|
if (beh_key)
|
|
sql_ex += " AND prs_perslid_key_beh =" + beh_key;
|
|
if (deel)
|
|
sql_ex += " AND ins_deel_upper LIKE " + safe.quoted_sql_wild("%" + deel + "%");
|
|
if (deel_opm)
|
|
sql_ex += " AND UPPER(ins_deel_opmerking) LIKE " + safe.quoted_sql_wild("%" + deel_opm + "%");
|
|
if (objsrt_oms)
|
|
sql_ex += " AND ( (ins_srtdeel_upper LIKE " + safe.quoted_sql_wild("%" + objsrt_oms + "%") + ")"
|
|
+ " OR (ins_srtdeel_code_upper LIKE " + safe.quoted_sql_wild("%" + objsrt_oms + "%") + "))";
|
|
if (groep)
|
|
sql_ex += " AND UPPER(groepoms) LIKE " + safe.quoted_sql_wild("%" + groep + "%");
|
|
|
|
if (inspect && ctrdisc_key > -1)
|
|
sql_ex += " AND ispn.ctr_disc_key = " + ctrdisc_key;
|
|
|
|
sql_ex += getKenmerkSql("INS", "i.ins_deel_key");
|
|
|
|
var sql_score = "";
|
|
if (mjob)
|
|
{
|
|
// Conditie score.
|
|
// Niet gemeten objecten doen wel mee in dit filter. Deze objecten worden dus niet getoond als er een waarde is ingevuld.
|
|
if (fitness_score1_from > 0)
|
|
sql_score += " AND i.ins_deel_mjb_score1 >= " + fitness_score1_from;
|
|
if (fitness_score1_through > 0)
|
|
sql_score += " AND i.ins_deel_mjb_score1 <= " + fitness_score1_through;
|
|
|
|
// Grenswaarde conditie score.
|
|
// Niet gemeten objecten doen wel mee in dit filter. Deze objecten worden dus niet getoond als er een waarde is ingevuld.
|
|
if (gwfitness_score1_from > 0)
|
|
sql_score += " AND s.ins_srtdeel_mjb_grensscore1 >= " + gwfitness_score1_from;
|
|
if (gwfitness_score1_through > 0)
|
|
sql_score += " AND s.ins_srtdeel_mjb_grensscore1 <= " + gwfitness_score1_through;
|
|
|
|
// Prioriteitsscore.
|
|
// Niet gemeten objecten doen wel mee in dit filter. Deze objecten worden dus niet getoond als er een waarde is ingevuld.
|
|
if (priority_score2_from > 0)
|
|
sql_score += " AND i.ins_deel_mjb_score2 >= " + priority_score2_from;
|
|
if (priority_score2_through > 0)
|
|
sql_score += " AND i.ins_deel_mjb_score2 <= " + priority_score2_through;
|
|
}
|
|
|
|
// Nu filtercondities voor scores en flexkenmerken toevoegen.
|
|
if (sqlPosition != "")
|
|
{
|
|
sqlPosition += sql_ex + sql_score;
|
|
if (auth_org)
|
|
sqlPosition_org += sql_ex + sql_score;
|
|
}
|
|
|
|
if (sqlPosition != "")
|
|
{ // we must consider this: if we know that a room is defined (by filter), we must be
|
|
// able to improve performance by using that condition, mustn't we?
|
|
// furthermore: it's better to let Oracle Prepare
|
|
sqlPosition = discx3d (sqlPosition,
|
|
"i.ins_discipline_key",
|
|
"di.alg_regio_key",
|
|
"l.alg_district_key",
|
|
"l.alg_locatie_key",
|
|
"o.alg_gebouw_key",
|
|
"o.alg_verdieping_key",
|
|
"o.alg_ruimte_key",
|
|
"", // b.prs_bedrijf_key: not used because algprs == 0
|
|
"", // d.prs_afdeling_key: not used because algprs == 0
|
|
pautfunction,
|
|
(disc_key? disc_key : ''),
|
|
0); // AKZA#430/PF, AKZA#496/MGE
|
|
|
|
if (auth_org)
|
|
sqlPosition_org = discx3d (sqlPosition_org,
|
|
"i.ins_discipline_key",
|
|
"di.alg_regio_key",
|
|
"l.alg_district_key",
|
|
"l.alg_locatie_key",
|
|
"o.alg_gebouw_key",
|
|
"o.alg_verdieping_key",
|
|
"o.alg_ruimte_key",
|
|
"", // b.prs_bedrijf_key: not used because algprs == 0
|
|
"", // d.prs_afdeling_key: not used because algprs == 0
|
|
pautfunction,
|
|
(disc_key? disc_key : ''),
|
|
0); // AKZA#430/PF, AKZA#496/MGE
|
|
}
|
|
|
|
if (sqlOwnerA != "" && sqlOwnerP != "" && sqlOwnerCP != "")
|
|
{
|
|
sqlOwnerA = discx3d (sqlOwnerA,
|
|
"ins_discipline_key",
|
|
"", // di.alg_regio_key: not used because algprs == 0
|
|
"", // l.alg_district_key: not used because algprs == 0
|
|
"", // o.alg_locatie_key: not used because algprs == 0
|
|
"", // o.alg_gebouw_key: not used because algprs == 0
|
|
"", // o.alg_verdieping_key: not used because algprs == 0
|
|
"", // o.alg_ruimte_key: not used because algprs == 0
|
|
"b.prs_bedrijf_key",
|
|
"d.prs_afdeling_key",
|
|
pautfunction,
|
|
(disc_key? disc_key : ''),
|
|
1); // AKZA#430/PF, AKZA#496/MGE
|
|
|
|
if (auth_org)
|
|
sqlOwnerA_org = discx3d (sqlOwnerA_org,
|
|
"ins_discipline_key",
|
|
"", // di.alg_regio_key: not used because algprs == 0
|
|
"", // l.alg_district_key: not used because algprs == 0
|
|
"", // o.alg_locatie_key: not used because algprs == 0
|
|
"", // o.alg_gebouw_key: not used because algprs == 0
|
|
"", // o.alg_verdieping_key: not used because algprs == 0
|
|
"", // o.alg_ruimte_key: not used because algprs == 0
|
|
"b.prs_bedrijf_key",
|
|
"d.prs_afdeling_key",
|
|
pautfunction,
|
|
(disc_key? disc_key : ''),
|
|
1); // AKZA#430/PF, AKZA#496/MGE
|
|
|
|
sqlOwnerP = discx3d (sqlOwnerP,
|
|
"ins_discipline_key",
|
|
"", // di.alg_regio_key: not used because algprs == 0
|
|
"", // l.alg_district_key: not used because algprs == 0
|
|
"", // o.alg_locatie_key: not used because algprs == 0
|
|
"", // o.alg_gebouw_key: not used because algprs == 0
|
|
"", // o.alg_verdieping_key: not used because algprs == 0
|
|
"", // o.alg_ruimte_key: not used because algprs == 0
|
|
"b.prs_bedrijf_key",
|
|
"d.prs_afdeling_key",
|
|
pautfunction,
|
|
(disc_key? disc_key : ''),
|
|
1); // AKZA#430/PF, AKZA#496/MGE
|
|
// Geen autorisatie bij externe bedrijven (prs_bedrijf)
|
|
|
|
if (auth_org)
|
|
sqlOwnerP_org = discx3d (sqlOwnerP_org,
|
|
"ins_discipline_key",
|
|
"", // di.alg_regio_key: not used because algprs == 0
|
|
"", // l.alg_district_key: not used because algprs == 0
|
|
"", // o.alg_locatie_key: not used because algprs == 0
|
|
"", // o.alg_gebouw_key: not used because algprs == 0
|
|
"", // o.alg_verdieping_key: not used because algprs == 0
|
|
"", // o.alg_ruimte_key: not used because algprs == 0
|
|
"b.prs_bedrijf_key",
|
|
"d.prs_afdeling_key",
|
|
pautfunction,
|
|
(disc_key? disc_key : ''),
|
|
1); // AKZA#430/PF, AKZA#496/MGE
|
|
|
|
// Deelqueries sqlOwnerA en sqlOwnerCP leveren alleen resultaat op als
|
|
// 1) "Beschikbaar" (insAvail) is aangevinkt of
|
|
// 2) Niet naar de _org autorisatie gekeken hoeft te worden (!auth_org).
|
|
// !auth_org = S("ins_auth_obj_lendout") == 0 || !fronto || !insLentOut;
|
|
// = Authorization scope for objects which are lended out is 0=owner(borrower) of
|
|
// ik zit niet bij uitleenregistratie of
|
|
// object is niet uitgeleend.
|
|
sqlOwner = (insAvail || !auth_org
|
|
? sqlOwnerA + sql_ex + sql_score + " UNION " + sqlOwnerCP + sql_ex + sql_score + " UNION "
|
|
: "")
|
|
+ sqlOwnerP + sql_ex + sql_score
|
|
+ (auth_org // S("ins_auth_obj_lendout") == 1 && fronto && insLentOut
|
|
? " UNION " + sqlOwnerA_org + sql_ex + sql_score + " UNION " + sqlOwnerP_org + sql_ex + sql_score + " UNION " + sqlOwnerCP_org + sql_ex + sql_score
|
|
: "");
|
|
|
|
// Now apply user filtering on this query:
|
|
if (persoon_key)
|
|
{
|
|
sqlOwner = "SELECT * FROM (" + sqlOwner + ") x WHERE x.ins_alg_ruimte_type = 'P' AND x.alg_ruimte_key = " + persoon_key;
|
|
}
|
|
else if (cpersoon_key)
|
|
{
|
|
sqlOwner = "SELECT * FROM (" + sqlOwner + ") x WHERE x.ins_alg_ruimte_type = 'C' AND x.alg_ruimte_key = " + cpersoon_key;
|
|
}
|
|
else if (dep_key)
|
|
{
|
|
sqlOwner = "SELECT * FROM (" + sqlOwner + ") x WHERE x.prs_afdeling_key = " + dep_key;
|
|
}
|
|
else if (comp_key)
|
|
{
|
|
sqlOwner = "SELECT * FROM (" + sqlOwner + ") x WHERE x.prs_bedrijf_key = " + comp_key;
|
|
}
|
|
}
|
|
|
|
sql = (sqlOwner != ""
|
|
? sqlOwner + (sqlPosition != ""? " UNION ALL " : "")
|
|
: "")
|
|
+ sqlPosition
|
|
+ (auth_org && sqlPosition != ""
|
|
? " UNION " + sqlPosition_org
|
|
: "");
|
|
|
|
if (inspect)
|
|
{
|
|
sql += " AND (ins_deel_vervaldatum IS NULL OR ins_deel_vervaldatum > SYSDATE)";
|
|
// drie vinkjes 111 is 'te laat', 'binnenkort', 'nog niet'
|
|
|
|
|
|
// De binnenkort tijden.
|
|
// Let op: Als de "Binnenkort" datums worden veranderd, wordt de tijd aangepast in begin van de dag (00:00).
|
|
// Als de inspsoonfrom tijd vandaag is moet ook de huidige tijd mee worden genomen. Ander niet.
|
|
var inspsoonfrom_is_today = false;
|
|
var dtsoonfrom = null;
|
|
if (inspsoonfrom)
|
|
{
|
|
// Als de inspsoonfrom tijd vandaag is moet ook de huidige tijd mee worden genomen. Ander niet.
|
|
// Als de inspsoon tijden worden veranderd wordt de tijd begin van de dag (00:00).
|
|
inspsoonfrom_is_today = (inspsoonfrom.midnight().getTime() == new Date().midnight().getTime());
|
|
if (inspsoonfrom_is_today)
|
|
{ // De inspsoonfrom is vandaag. De huidige tijd meenemen.
|
|
var time = new Date().getTime() - new Date().midnight().getTime();
|
|
dtsoonfrom = new Date(inspsoonfrom.midnight().getTime() + time);
|
|
}
|
|
else
|
|
// De inspsoonfrom is NIET vandaag. De tijd wordt begin van de dag (00:00).
|
|
dtsoonfrom = new Date(inspsoonfrom.midnight().getTime());
|
|
}
|
|
|
|
var dtsoonto = null;
|
|
if (inspsoonto)
|
|
{
|
|
var inspsoonto_is_today = (inspsoonto.midnight().getTime() == new Date().midnight().getTime());
|
|
if (inspsoonto_is_today)
|
|
dtsoonto = new Date(inspsoonto.setHours(23, 59, 59)); // Beide datums zijn vandaag. Dan dtsoonto einde van de dag nemen.
|
|
else if (inspsoonfrom_is_today)
|
|
{ // De inspsoonfrom is vandaag. Ook voor de tot datum de huidige tijd meenemen.
|
|
var time = new Date().getTime() - new Date().midnight().getTime();
|
|
dtsoonto = new Date(inspsoonto.midnight().getTime() + time);
|
|
}
|
|
else
|
|
// De inspsoonfrom is NIET vandaag. De tijd wordt eind van de dag (23:59).
|
|
dtsoonto = new Date(inspsoonto.setHours(23, 59, 59));
|
|
}
|
|
|
|
// De afgehandeld tijden.
|
|
// Let op: Als de donedateto tijd vandaag is moet ook de huidige tijd mee worden genomen. Ander niet.
|
|
var donedateto_is_today = false;
|
|
var dtdonedateto = null;
|
|
if (donedateto)
|
|
{
|
|
// Als de donedateto tijd vandaag is moet ook de huidige tijd mee worden genomen. Ander niet.
|
|
// Als de donedate tijden worden veranderd wordt de tijd eind van de dag (23:59).
|
|
donedateto_is_today = (donedateto.midnight().getTime() == new Date().midnight().getTime());
|
|
if (donedateto_is_today)
|
|
{ // De donedateto is vandaag. De huidige tijd meenemen.
|
|
var time = new Date().getTime() - new Date().midnight().getTime();
|
|
dtdonedateto = new Date(donedateto.midnight().getTime() + time);
|
|
}
|
|
else
|
|
// De donedateto is NIET vandaag. De tijd wordt eind van de dag (23:59).
|
|
dtdonedateto = new Date(donedateto.setHours(23, 59, 59));
|
|
}
|
|
|
|
var dtdonedatefrom = null;
|
|
if (donedatefrom)
|
|
{
|
|
var donedatefrom_is_today = (donedatefrom.midnight().getTime() == new Date().midnight().getTime());
|
|
if (donedatefrom_is_today)
|
|
dtdonedatefrom = new Date(donedatefrom.midnight().getTime()); // Beide datums zijn vandaag. Dan dtdonedatefrom begin van de dag nemen.
|
|
else if (donedateto_is_today)
|
|
{ // De donedateto is vandaag. Ook voor de van datum de huidige tijd meenemen.
|
|
var time = new Date().getTime() - new Date().midnight().getTime();
|
|
dtdonedatefrom = new Date(donedatefrom.midnight().getTime() + time);
|
|
}
|
|
else
|
|
// De inspsoonfrom is NIET vandaag. De tijd wordt begin van de dag (00:00).
|
|
dtdonedatefrom = new Date(donedatefrom.midnight().getTime());
|
|
}
|
|
|
|
var sqlBC = (inspClosed || inspBusy
|
|
? "x.ins_deelsrtcontrole_status IN ("
|
|
+ (inspBusy? "2" : "")
|
|
+ (inspClosed && inspBusy? ", " : "")
|
|
+ (inspClosed? "5" : "")
|
|
+ ")"
|
|
: "");
|
|
|
|
if (inspDone)
|
|
{
|
|
if (dtdonedatefrom != null && dtdonedateto != null)
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE inspectie_date BETWEEN " + dtdonedatefrom.toSQL(true) + " AND " + dtdonedateto.toSQL(true);
|
|
else if (dtdonedatefrom == null && dtdonedateto != null)
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE inspectie_date < " + dtdonedateto.toSQL(true);
|
|
else if (dtdonedatefrom != null && dtdonedateto == null)
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE inspectie_date BETWEEN " + dtdonedatefrom.toSQL(true) + " AND SYSDATE";
|
|
else if (dtdonedatefrom == null && dtdonedateto == null)
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE inspectie_date < SYSDATE";
|
|
}
|
|
else if (inspSoon) // Binnenkort is aangevinkt.
|
|
{
|
|
if (dtsoonfrom != null && dtsoonto != null) // Binnenkort.
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE (COALESCE(ins_deelsrtcontrole_plandatum, inspectie_next) BETWEEN " + dtsoonfrom.toSQL(true) + " AND " + dtsoonto.toSQL(true) + (sqlBC != ''? " OR " + sqlBC : "") + ")";
|
|
else if (dtsoonfrom == null && dtsoonto != null) // Te laat + binnenkort.
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE (COALESCE(ins_deelsrtcontrole_plandatum, inspectie_next) < " + dtsoonto.toSQL(true) + (sqlBC != ''? " OR " + sqlBC : "") + ")";
|
|
else if (dtsoonfrom != null && dtsoonto == null) // Binnenkort + toekomst.
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE (COALESCE(ins_deelsrtcontrole_plandatum, inspectie_next) >= " + dtsoonfrom.toSQL(true) + (sqlBC != ''? " OR " + sqlBC : "") + ")";
|
|
else if (dtsoonfrom == null && dtsoonto == null)
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE 1 = 1"; // Alles tonen onafhankelijk van sqlBC.
|
|
}
|
|
else if (inspBusy || inspClosed) // Onderhanden (inspBusy), vervolgactie vereist (inspClosed).
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE " + sqlBC;
|
|
else // Geen checkbox aangevinkt.
|
|
sql = "SELECT * FROM (" + sql + ") x WHERE 1 = 1"; // Alles tonen.
|
|
|
|
if (cnt_bedrijf_key > 0) // alleen bedrijven met een (onderhouds)contract op deze soorten
|
|
{
|
|
// Scope srtcontract_type = 3 (Ondersteuning/Support): Onderhoud op objectsoorten en/of plaats.
|
|
// Scope op de plaats is een verfijning van de scope op de gehele objectsoort.
|
|
// Scope op objectsoorten
|
|
sql += " AND ((((SELECT COUNT(*)"
|
|
+ " FROM cnt_contract_object co"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_status IN (0, 1)" // Alleen actieve en gesloten contracten
|
|
+ " AND cnt_contract_object_verwijder IS NULL) = 0" // Er zijn geen objectsoorten gedefinieerd
|
|
+ " OR"
|
|
+ " x.ins_srtdeel_key IN (SELECT cnt_ins_srtdeel_key"
|
|
+ " FROM cnt_contract_object co"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_contract_object_verwijder IS NULL"
|
|
+ " AND co.cnt_ins_deel_key IS NULL"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " )"
|
|
+ " )"
|
|
// Scope op plaats
|
|
+ " AND ((SELECT COUNT(*)"
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL) = 0" // Er zijn geen plaatsen gedefinieerd
|
|
+ " OR"
|
|
+ " ins_deel_key IN (SELECT d.ins_deel_key" // Delen die gekoppeld zijn aan een ruimte
|
|
+ " FROM ins_deel d"
|
|
+ " , alg_v_onrgoed_boom ogb"
|
|
+ " WHERE d.ins_alg_ruimte_key = ogb.alg_ruimte_key"
|
|
+ " AND d.ins_alg_ruimte_type = 'R'"
|
|
+ " AND ogb.alg_gebouw_key IN (SELECT DISTINCT g.alg_gebouw_key" // Alle gebouwen van de locaties in de scope
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , alg_gebouw g"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE g.alg_locatie_key = cp.cnt_alg_plaats_key"
|
|
+ " AND cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'L'"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " UNION"
|
|
+ " SELECT DISTINCT cp.cnt_alg_plaats_key" // Alle gebouwen van de gebouwen in de scope
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'G'"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " )"
|
|
+ " UNION"
|
|
+ " SELECT d.ins_deel_key" // Delen die gekoppeld zijn aan een werkplek
|
|
+ " FROM ins_deel d"
|
|
+ " , prs_werkplek w"
|
|
+ " , alg_v_onrgoed_boom ogb"
|
|
+ " WHERE d.ins_alg_ruimte_key = w.prs_werkplek_key"
|
|
+ " AND w.prs_alg_ruimte_key = ogb.alg_ruimte_key"
|
|
+ " AND d.ins_alg_ruimte_type = 'W'"
|
|
+ " AND ogb.alg_gebouw_key IN (SELECT DISTINCT g.alg_gebouw_key" // Alle gebouwen van de locaties in de scope
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , alg_gebouw g"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE g.alg_locatie_key = cp.cnt_alg_plaats_key"
|
|
+ " AND cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'L'"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " UNION"
|
|
+ " SELECT DISTINCT cp.cnt_alg_plaats_key" // Alle gebouwen van de gebouwen in de scope
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'G'"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " )"
|
|
+ " )"
|
|
+ " )"
|
|
// Objecten mogen niet individueel in contractscope zitten van een ander bedrijf
|
|
+ " AND ins_deel_key NOT IN (SELECT co.cnt_ins_deel_key"
|
|
+ " FROM cnt_contract_object co"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_ins_deel_key IS NOT NULL"
|
|
+ " AND co.cnt_contract_object_verwijder IS NULL"
|
|
+ " AND c.cnt_prs_bedrijf_key != " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " AND c.cnt_contract_looptijd_van <= SYSDATE" // Alleen actuele contracten
|
|
+ " AND SYSDATE <= c.cnt_contract_looptijd_tot)"
|
|
// Objecten mogen ook niet qua objectsoort in contractscope zitten van een ander bedrijf
|
|
+ " AND ins_deel_key NOT IN (SELECT d1.ins_deel_key" // Alle objecten via plaatsscope van andere bedrijven die ook dezelfde objectscope hebben (gekoppeld aan een ruimte)
|
|
+ " FROM ins_deel d1"
|
|
+ " , alg_v_onrgoed_boom ogb"
|
|
+ " WHERE d1.ins_alg_ruimte_key = ogb.alg_ruimte_key"
|
|
+ " AND d1.ins_alg_ruimte_type = 'R'" // gekoppeld aan een ruimte
|
|
+ " AND x.ins_srtdeel_key = d1.ins_srtdeel_key"
|
|
+ " AND ogb.alg_gebouw_key IN (SELECT DISTINCT g.alg_gebouw_key" // Alle gebouwen via plaatsscope van andere bedrijven die ook dezelfde objectscope hebben
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , alg_gebouw g"
|
|
+ " , cnt_contract c"
|
|
+ " , cnt_contract_object co"
|
|
+ " WHERE g.alg_locatie_key = cp.cnt_alg_plaats_key"
|
|
+ " AND cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key != " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_looptijd_van <= SYSDATE" // Alleen actuele contracten
|
|
+ " AND SYSDATE <= c.cnt_contract_looptijd_tot"
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'L'"
|
|
+ " AND co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_ins_srtdeel_key = d1.ins_srtdeel_key"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " UNION"
|
|
+ " SELECT DISTINCT cp.cnt_alg_plaats_key"
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , cnt_contract c"
|
|
+ " , cnt_contract_object co"
|
|
+ " WHERE cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key != " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_looptijd_van <= SYSDATE" // Alleen actuele contracten
|
|
+ " AND SYSDATE <= c.cnt_contract_looptijd_tot"
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'G'"
|
|
+ " AND co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_ins_srtdeel_key = d1.ins_srtdeel_key"
|
|
+ " AND c.cnt_contract_status IN (0, 1))"
|
|
+ " UNION"
|
|
+ " SELECT d1.ins_deel_key" // Alle objecten via plaatsscope van andere bedrijven die ook dezelfde objectscope hebben (gekoppeld aan een werkplek)
|
|
+ " FROM ins_deel d1"
|
|
+ " , prs_werkplek w"
|
|
+ " , alg_v_onrgoed_boom ogb"
|
|
+ " WHERE d1.ins_alg_ruimte_key = w.prs_werkplek_key"
|
|
+ " AND w.prs_alg_ruimte_key = ogb.alg_ruimte_key"
|
|
+ " AND d1.ins_alg_ruimte_type = 'W'" // gekoppeld aan een werkplek
|
|
+ " AND ogb.alg_gebouw_key IN (SELECT DISTINCT g.alg_gebouw_key" // Alle gebouwen via plaatsscope van andere bedrijven die ook dezelfde objectscope hebben
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , alg_gebouw g"
|
|
+ " , cnt_contract c"
|
|
+ " , cnt_contract_object co"
|
|
+ " WHERE g.alg_locatie_key = cp.cnt_alg_plaats_key"
|
|
+ " AND cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key != " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_looptijd_van <= SYSDATE" // Alleen actuele contracten
|
|
+ " AND SYSDATE <= c.cnt_contract_looptijd_tot"
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'L'"
|
|
+ " AND co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_ins_srtdeel_key = d1.ins_srtdeel_key"
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " UNION"
|
|
+ " SELECT DISTINCT cp.cnt_alg_plaats_key"
|
|
+ " FROM cnt_contract_plaats cp"
|
|
+ " , cnt_contract c"
|
|
+ " , cnt_contract_object co"
|
|
+ " WHERE cp.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND c.cnt_prs_bedrijf_key != " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_looptijd_van <= SYSDATE" // Alleen actuele contracten
|
|
+ " AND SYSDATE <= c.cnt_contract_looptijd_tot"
|
|
+ " AND cnt_contract_plaats_verwijder IS NULL"
|
|
+ " AND cp.cnt_alg_plaats_code = 'G'"
|
|
+ " AND co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_ins_srtdeel_key = d1.ins_srtdeel_key"
|
|
+ " AND c.cnt_contract_status IN (0, 1))"
|
|
+ " )"
|
|
+ " )"
|
|
|
|
// Scope srtcontract_type = 1 (Onderhoud/Maintenance): Onderhoud op objecten.
|
|
// Scope op de objecten.
|
|
sql += " OR ins_deel_key IN (SELECT co.cnt_ins_deel_key"
|
|
+ " FROM cnt_contract_object co"
|
|
+ " , cnt_contract c"
|
|
+ " WHERE co.cnt_contract_key = c.cnt_contract_key"
|
|
+ " AND co.cnt_ins_deel_key IS NOT NULL"
|
|
+ " AND co.cnt_contract_object_verwijder IS NULL"
|
|
+ " AND c.cnt_prs_bedrijf_key = " + cnt_bedrijf_key
|
|
+ " AND c.cnt_contract_status IN (0, 1)"
|
|
+ " )"
|
|
+ " )";
|
|
}
|
|
}
|
|
|
|
sql = "SELECT * FROM (" + sql + ") XX ORDER BY"
|
|
+ (koppel_key?" case when xx.ins_deel_key = ins_deelkoppeling_van_key THEN 1 ELSE 0 END,":"")
|
|
+ (outputmode == 2 // excel moet objecten met gelijke kenmerken bij elkaar hebben
|
|
? " ins_srtdeel_upper, plaats, soort, ins_deel_omschrijving"
|
|
: (mobile? " plaats, ins_deel_omschrijving, soort" : " ins_deel_omschrijving"
|
|
+ (inspDone? ", inspectie_date" : "")
|
|
+ ", plaats, ins_disc_oms, ins_groep_oms, soort"));
|
|
|
|
return sql;
|
|
},
|
|
|
|
getmjblist_sql:
|
|
function (params)
|
|
{ // Lever de mjbsearchlist sql op.
|
|
var inflatiepct = S("mjb_inflation");
|
|
var inflatiefactor = 1 + (inflatiepct / 100);
|
|
var mjb_start_year = S("mjb_start_year");
|
|
var mjb_freeze_year = S("mjb_freeze_year");
|
|
|
|
var keys = params.keys;
|
|
var niveau = params.niveau;
|
|
var scenario = params.scenario;
|
|
var fulldetails = params.fulldetails;
|
|
var actsit = params.actsit;
|
|
var dist_key = params.dist_key;
|
|
var loc_key = params.loc_key;
|
|
var bld_key = params.bld_key;
|
|
var disc_key = params.disc_key;
|
|
var srtgroep_key = params.srtgroep_key;
|
|
var srtdeel_key = params.srtdeel_key;
|
|
var groep = params.groep;
|
|
var categorie_key = params.categorie_key;
|
|
var srtcontrole = params.srtcontrole;
|
|
var frequentie = params.frequentie;
|
|
var kp_key = params.kp_key;
|
|
var incbtw = params.incbtw;
|
|
var toyear = params.toyear;
|
|
var groupby = params.groupby;
|
|
var deel = params.deel;
|
|
var fitness_score1_from = params.fitness_score1_from;
|
|
var fitness_score1_through = params.fitness_score1_through;
|
|
var fitness_score1_from_neg = params.fitness_score1_from_neg;
|
|
var fitness_score1_through_neg = params.fitness_score1_through_neg;
|
|
var fitness_score1_from_pos = params.fitness_score1_from_pos;
|
|
var fitness_score1_through_pos = params.fitness_score1_through_pos;
|
|
var priority_score2_from = params.priority_score2_from;
|
|
var priority_score2_through = params.priority_score2_through;
|
|
var mjbMoved = params.mjbMoved;
|
|
var mjbFreezed = params.mjbFreezed;
|
|
var mjbXcped = params.mjbXcped;
|
|
var sel_controlemode123 = params.sel_controlemode123;
|
|
var jaren = params.jaren;
|
|
var freeze = params.freeze;
|
|
var finish = params.finish;
|
|
var getsumtypes = params.getsumtypes;
|
|
var deelscore1 = params.deelscore1;
|
|
var deelscore2 = params.deelscore2;
|
|
|
|
// De datum (jaar) van de *eerstvolgende* onderhoudsbeurt volgt uit:
|
|
// Datum laatste (/laatste geplande) inspectie
|
|
// of anders: ins_deel_aanmaak
|
|
// waarbij verondersteld wordt dat inspecties in het verleden wel zijn uitgevoerd
|
|
|
|
// SQL van objecten met hun eerste vervanging
|
|
var sql_componenten =
|
|
"SELECT e.ins_deel_key"
|
|
+ " , e.ins_srtcontroledl_xcp_key"
|
|
+ " , e.ins_srtcontrole_key"
|
|
+ " , e.ins_srtcontrole_level"
|
|
+ " , e.ins_srtcontrole_omschrijving"
|
|
+ " , e.ins_srtcontrole_kosten"
|
|
+ " , e.ins_srtcontrole_kosten2"
|
|
+ " , e.ins_srtcontrole_kosten3"
|
|
+ " , e.ins_srtcontrole_materiaal"
|
|
+ " , e.ins_srtcontrole_periode"
|
|
+ " , e.ins_srtcontrole_percentage"
|
|
+ " , e.ins_srtcontrole_opmerking"
|
|
// Bepaling in welk jaar er een inspectie is gepland.
|
|
// 1) In het jaar van de plandatum.
|
|
// 2) In het jaar van de startdatum.
|
|
// 3) a) Laatste inspectie is NULL (eerste inspectie moet nog komen) en het is een Controle(1).
|
|
// Volgende inspectie is in het freeze jaar.
|
|
// b) Laatste inspectie is NULL (eerste inspectie moet nog komen) en het is een Vervanging(2) of Certificering(3).
|
|
// Nextdate is na het freeze jaar?
|
|
// Ja) Vorige inspectie ligt na het start jaar en ligt niet in het aanmaak jaar?
|
|
// Ja) Volgende inspectie is in het freeze jaar.
|
|
// Nee) Volgende inspectie is het jaar van de nextdate.
|
|
// Nee) De laatst ingeplande inspectie (nextdate) is na of in het start jaar?
|
|
// Ja) Volgende inspectie is in het freeze jaar.
|
|
// Nee) Volgende inspectie is in het jaar "nextdatum + periode".
|
|
// c) Laatste inspectie is niet NULL. Er is al 1 of meerdere keren geinspecteerd.
|
|
// Ligt de laatst ingeplande inspectie (nextdate) na dit jaar?
|
|
// Ja) Volgende inspectie is het jaar van de nextdate (in de toekomst).
|
|
// Nee) Volgende inspectie is in het freeze jaar.
|
|
+ " , EXTRACT (YEAR FROM COALESCE(c.plandatum" // Plandatum.
|
|
+ " , CASE" // Eventueel startdatum (ins_srtcontroledl_xcp_startdat) i.g.v. als er nog geen inspectie heeft plaatsgevonden.
|
|
+ " WHEN c.laatste IS NULL" // Als er al een inspectie is geweest, is de startdatum niet meer van belang.
|
|
+ " THEN e.ins_srtcontroledl_xcp_startdat"
|
|
+ " ELSE NULL"
|
|
+ " END"
|
|
+ " , CASE" // Berekenen jaar.
|
|
+ " WHEN c.laatste IS NULL AND e.ctr_controle_type = 1" // 1: Controle.
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " WHEN c.laatste IS NULL AND e.ctr_controle_type != 1" // 2: Vervanging, 3: Certificering.
|
|
+ " THEN" // Er is nog geen inspectie geweest
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.nextdate) > " + mjb_freeze_year
|
|
+ " THEN" // Nextdate is na de freeze datum.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM ADD_MONTHS(e.nextdate, -1 * 12 * e.ins_srtcontrole_periode)) >= " + mjb_start_year + " AND"
|
|
+ " EXTRACT(YEAR FROM ADD_MONTHS(e.nextdate, -1 * 12 * e.ins_srtcontrole_periode)) != EXTRACT(YEAR FROM e.ins_deel_aanmaak)"
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Nu en vorige inspectie liggen tussen start en freeze jaar.
|
|
+ " ELSE e.nextdate"
|
|
+ " END"
|
|
+ " ELSE" // Nextdate is voor of in het freeze jaar.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.nextdate) >= " + mjb_start_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Nextdate tussen start en freeze jaar.
|
|
+ " ELSE ADD_MONTHS(e.nextdate, 12 * e.ins_srtcontrole_periode)" // Nextdate voor het start jaar.
|
|
+ " END"
|
|
+ " END"
|
|
+ " ELSE" // Laatste IS NOT NULL. Er is al een inspectie geweest.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.nextdate) > EXTRACT(YEAR FROM SYSDATE)"
|
|
+ " THEN e.nextdate" // Volgende inspectie is in de toekomst.
|
|
+ " ELSE TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Laatst ingeplande inspectie is nog niet uitgevoerd.
|
|
+ " END"
|
|
+ " END)) vervangingsjaar"
|
|
// Eerste inspectie datum bepalen zonder na de plandatum te kijken (orginele inspectie datum).
|
|
// Als de registratiedatum in de toekomst ligt en de startdatum eventueel ook dan geldt het volgende.
|
|
// Voor Controle(1): Eerste inspectie tonen op MAX(startdatum, registratiedatum) van het object.
|
|
// Voor Vervanging(2) of Certificering(3):
|
|
// a) Als registratiedatum het verst in de toekomst ligt: Eerste inspectie tonen op 1 periode verder dan de registratiedatum.
|
|
// b) Als de startdatum het verst in de toekomst ligt: Eerste inspectie tonen op de startdatum.
|
|
// De aanmaakdatum/Registratiedatum is altijd ingevuld en als er al een inspectie is geweest, zijn de startdatum en registratiedatum niet meer van belang.
|
|
+ " , EXTRACT (YEAR FROM COALESCE(CASE" // Startdatum of registratiedatum in de toekomst en er is nog geen inspectie geweest.
|
|
+ " WHEN c.laatste IS NULL AND"
|
|
+ " (e.ins_srtcontroledl_xcp_startdat IS NOT NULL AND"
|
|
+ " (EXTRACT(YEAR FROM e.ins_srtcontroledl_xcp_startdat) > EXTRACT(YEAR FROM SYSDATE) OR"
|
|
+ " EXTRACT(YEAR FROM e.ins_deel_aanmaak) > EXTRACT(YEAR FROM SYSDATE)))"
|
|
+ " THEN" // Startdatum is ingevuld en ligt in de toekomst en er is nog geen inspectie geweest.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.ins_srtcontroledl_xcp_startdat) >= EXTRACT(YEAR FROM e.ins_deel_aanmaak)"
|
|
+ " THEN" // Startdatum op of na aanmaakdatum/registratiedatum.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.ins_srtcontroledl_xcp_startdat) < " + mjb_freeze_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " ELSE e.ins_srtcontroledl_xcp_startdat"
|
|
+ " END"
|
|
+ " ELSE" // Aanmaakdatum/Registratiedatum is na de startdatum.
|
|
+ " CASE"
|
|
+ " WHEN e.ctr_controle_type = 1" // 1: Controle.
|
|
+ " THEN"
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.ins_deel_aanmaak) < " + mjb_freeze_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " ELSE e.ins_deel_aanmaak" // Registratiedatum.
|
|
+ " END"
|
|
+ " ELSE" // 2: Vervanging, 3: Certificering.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM ADD_MONTHS(e.ins_deel_aanmaak, 12 * e.ins_srtcontrole_periode)) < " + mjb_freeze_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " ELSE ADD_MONTHS(e.ins_deel_aanmaak, 12 * e.ins_srtcontrole_periode)" // 1 periode na registratiedatum.
|
|
+ " END"
|
|
+ " END"
|
|
+ " END"
|
|
+ " WHEN c.laatste IS NULL AND"
|
|
+ " EXTRACT(YEAR FROM e.ins_deel_aanmaak) > EXTRACT(YEAR FROM SYSDATE)" // Alleen de aanmaakdatum/registratiedatum is ingevuld.
|
|
+ " THEN" // Aanmaakdatum/Registratiedatum is ingevuld en ligt in de toekomst en er is nog geen inspectie geweest.
|
|
+ " CASE"
|
|
+ " WHEN e.ctr_controle_type = 1" // 1: Controle.
|
|
+ " THEN"
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT( YEAR FROM e.ins_deel_aanmaak) < " + mjb_freeze_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " ELSE e.ins_deel_aanmaak"
|
|
+ " END"
|
|
+ " ELSE" // 2: Vervanging, 3: Certificering.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT( YEAR FROM ADD_MONTHS(e.ins_deel_aanmaak, 12 * e.ins_srtcontrole_periode)) < " + mjb_freeze_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " ELSE ADD_MONTHS(e.ins_deel_aanmaak, 12 * e.ins_srtcontrole_periode)"
|
|
+ " END"
|
|
+ " END"
|
|
+ " ELSE NULL"
|
|
+ " END"
|
|
+ " , CASE" // Berekenen jaar.
|
|
+ " WHEN c.laatste IS NULL AND e.ctr_controle_type = 1" // 1: Controle.
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')"
|
|
+ " WHEN c.laatste IS NULL AND e.ctr_controle_type != 1" // 2: Vervanging, 3: Certificering.
|
|
+ " THEN" // Er is nog geen inspectie geweest
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.nextdate) > " + mjb_freeze_year
|
|
+ " THEN" // Nextdate is na de freeze datum.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM ADD_MONTHS(e.nextdate, -1 * 12 * e.ins_srtcontrole_periode)) >= " + mjb_start_year + " AND"
|
|
+ " EXTRACT(YEAR FROM ADD_MONTHS(e.nextdate, -1 * 12 * e.ins_srtcontrole_periode)) != EXTRACT(YEAR FROM e.ins_deel_aanmaak)"
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Nu en vorige inspectie liggen tussen start en freeze jaar.
|
|
+ " ELSE e.nextdate"
|
|
+ " END"
|
|
+ " ELSE" // Nextdate is voor of in het freeze jaar.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.nextdate) >= " + mjb_start_year
|
|
+ " THEN TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Nextdate tussen start en freeze jaar.
|
|
+ " ELSE ADD_MONTHS(e.nextdate, 12 * e.ins_srtcontrole_periode)" // Nextdate voor het start jaar.
|
|
+ " END"
|
|
+ " END"
|
|
+ " ELSE" // Laatste IS NOT NULL. Er is al een inspectie geweest.
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM e.nextdate) > EXTRACT(YEAR FROM SYSDATE)"
|
|
+ " THEN e.nextdate" // Volgende inspectie is in de toekomst.
|
|
+ " ELSE TO_DATE('" + mjb_freeze_year + "', 'YYYY')" // Laatst ingeplande inspectie is nog niet uitgevoerd.
|
|
+ " END"
|
|
+ " END)) org_nextdate"
|
|
+ " , c.plandatum"
|
|
+ " , e.ins_deel_aantal"
|
|
+ " , e.ins_srtdeel_eenheid"
|
|
+ " , e.ins_srtcontrole_eind"
|
|
+ " , e.ins_srtcontrole_afbouwtijd"
|
|
+ " , e.prs_kostenplaats_key"
|
|
+ " , e.fin_btwtabelwaarde_key"
|
|
+ " , e.ins_srtcontroledl_xcp_startdat"
|
|
+ " , e.ins_srtcontroledl_xcp_eind"
|
|
+ " , e.ctr_controle_type"
|
|
+ " , e.ins_scenario_key"
|
|
+ " , e.hasscenario2"
|
|
+ " , e.scenario_oms"
|
|
+ " , e.scenario_aantal"
|
|
+ " , c.ins_deelsrtcontrole_freezedate"
|
|
+ " , c.ins_deelsrtcontrole_freezecost"
|
|
+ " , c.ins_deelsrtcontrole_status"
|
|
+ " , CASE"
|
|
+ " WHEN c.hascontroles IS NULL"
|
|
+ " THEN 0"
|
|
+ " ELSE c.hascontroles"
|
|
+ " END hascontroles"
|
|
+ " FROM (SELECT el.ins_deel_key"
|
|
+ " , el.ins_srtcontroledl_xcp_key"
|
|
+ " , el.ins_srtcontrole_omschrijving"
|
|
+ " , el.ins_srtcontrole_kosten"
|
|
+ " , el.ins_srtcontrole_kosten2"
|
|
+ " , el.ins_srtcontrole_kosten3"
|
|
+ " , el.ins_srtcontrole_materiaal"
|
|
+ " , el.ins_deel_aanmaak"
|
|
+ " , el.ins_srtcontrole_periode"
|
|
+ " , el.ins_srtcontrole_percentage"
|
|
+ " , el.ins_srtcontrole_opmerking"
|
|
+ " , el.ins_srtcontrole_key"
|
|
+ " , el.ins_srtcontrole_level"
|
|
+ " , el.ins_deel_aantal"
|
|
+ " , el.ins_srtdeel_eenheid"
|
|
+ " , el.ins_srtcontrole_eind"
|
|
+ " , el.ins_srtcontrole_afbouwtijd"
|
|
+ " , el.prs_kostenplaats_key"
|
|
+ " , el.fin_btwtabelwaarde_key"
|
|
+ " , el.ins_srtcontroledl_xcp_startdat"
|
|
+ " , el.ins_srtcontroledl_xcp_eind"
|
|
+ " , el.ctr_controle_type"
|
|
+ " , ins.nextcyclusdate(el.ins_deel_key, el.ins_srtcontrole_key, 1, 0) nextdate"
|
|
+ " , el.ins_scenario_key"
|
|
+ (scenario > 1
|
|
? " , COALESCE((SELECT MAX(1)" // Heeft de periodieke taak ook de meegegeven scenario 'scenario'.
|
|
+ " FROM ins_srtcontroledl_xcp xcp2"
|
|
+ " WHERE xcp2.ins_deel_key = el.ins_deel_key"
|
|
+ " AND xcp2.ins_srtcontrole_key = el.ins_srtcontrole_key"
|
|
+ " AND xcp2.ins_scenario_key = " + scenario + "), 0)"
|
|
: " , 0") + " hasscenario2"
|
|
+ (fulldetails && scenario == 1 ?
|
|
" , (SELECT LISTAGG(isc.ins_scenario_omschrijving, ', ') WITHIN GROUP (ORDER BY isc.ins_scenario_omschrijving)"
|
|
+ " FROM ins_srtcontroledl_xcp xcp"
|
|
+ " , ins_scenario isc"
|
|
+ " WHERE xcp.ins_scenario_key = isc.ins_scenario_key "
|
|
+ " AND xcp.ins_srtcontrole_key = el.ins_srtcontrole_key"
|
|
+ " AND isc.ins_scenario_key <> 1" // actuele situatie niet meenemen
|
|
+ " AND xcp.ins_deel_key = el.ins_deel_key)"
|
|
: " , 'dummy'") + " scenario_oms"
|
|
+ (fulldetails && scenario == 1 ?
|
|
" , (SELECT COUNT(isc.ins_scenario_omschrijving)"
|
|
+ " FROM ins_srtcontroledl_xcp xcp"
|
|
+ " , ins_scenario isc"
|
|
+ " WHERE xcp.ins_scenario_key = isc.ins_scenario_key"
|
|
+ " AND xcp.ins_srtcontrole_key = el.ins_srtcontrole_key"
|
|
+ " AND isc.ins_scenario_key <> 1" // actuele situatie niet meetellen
|
|
+ " AND xcp.ins_deel_key = el.ins_deel_key)"
|
|
: " , -1") + " scenario_aantal"
|
|
+ " FROM ins_v_defined_inspect_xcp el"
|
|
+ " WHERE el.ins_srtcontrole_periode > 0"
|
|
+ (scenario == 1? " AND ins_scenario_key = 1" : (actsit ? "": " AND ins_scenario_key = " + scenario))
|
|
+ " AND el.ctr_ismjob = 1"
|
|
// Je moet read CTRUSE rechten hebben op de CTR disciplines om de taken te kunnen zien.
|
|
+ " AND el.ctr_discipline_key IN (SELECT w.ins_discipline_key"
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key "
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_read < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_read < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key
|
|
+ " AND w.ins_discipline_key = el.ctr_discipline_key)"
|
|
// Vroeg filteren is *heel* goed voor performance
|
|
+ (dist_key > 0
|
|
? " AND el.ins_alg_locatie_key IN (SELECT alg_locatie_key FROM alg_locatie WHERE alg_district_key = " + dist_key + ")"
|
|
: "")
|
|
+ (loc_key > 0
|
|
? " AND el.ins_alg_locatie_key = " + loc_key
|
|
: "")
|
|
+ (bld_key > 0 // elders in dit bestand wordt scherper gefilterd, deze is voor de performance
|
|
? " AND el.ins_alg_locatie_key = (SELECT alg_locatie_key FROM alg_gebouw WHERE alg_gebouw_key = " + bld_key + ")"
|
|
: "")
|
|
+ (disc_key > 0
|
|
? " AND el.ins_discipline_key = " + disc_key
|
|
: "")
|
|
+ (srtgroep_key > 0
|
|
? " AND el.ins_srtgroep_key = " + srtgroep_key
|
|
: "")
|
|
+ (srtdeel_key > 0
|
|
? " AND el.ins_srtdeel_key = " + srtdeel_key
|
|
: "")
|
|
+ (groep
|
|
? " AND UPPER(ins_srtcontrole_groep) LIKE " + safe.quoted_sql_wild("%" + groep + "%")
|
|
: "")
|
|
+ (categorie_key > 0
|
|
? " AND el.ctr_discipline_key = " + categorie_key
|
|
: "")
|
|
+ (srtcontrole.length > 0
|
|
? " AND el.ins_srtcontrole_key IN (" + srtcontrole.join(",") + ")"
|
|
: "")
|
|
+ (frequentie.length > 0
|
|
? " AND el.ins_srtcontrole_periode IN (" + frequentie.join(",") + ")"
|
|
: "")
|
|
+ (kp_key > 0
|
|
? " AND el.prs_kostenplaats_key = " + kp_key
|
|
: "")
|
|
+ " ) e"
|
|
+ " LEFT OUTER JOIN" // uitgevoerde taken
|
|
+ " (SELECT dsc.ins_srtcontrole_key"
|
|
+ " , dsc.ins_deel_key"
|
|
+ " , dsc.ins_scenario_key"
|
|
+ " , dsc.ins_deelsrtcontrole_freezedate"
|
|
+ " , dsc.ins_deelsrtcontrole_freezecost"
|
|
+ " , dsc.ins_deelsrtcontrole_status"
|
|
+ " , (SELECT MAX(dsc1.ins_deelsrtcontrole_plandatum)"
|
|
+ " FROM ins_deelsrtcontrole dsc1"
|
|
+ " WHERE dsc1.ins_deel_key = dsc.ins_deel_key"
|
|
+ " AND dsc1.ins_srtcontrole_key = dsc.ins_srtcontrole_key"
|
|
+ " AND dsc1.ins_scenario_key = dsc.ins_scenario_key"
|
|
+ " AND dsc1.ins_deelsrtcontrole_status < 5) plandatum"
|
|
+ " , MAX(dsc.ins_deelsrtcontrole_datum) laatste"
|
|
+ " , CASE"
|
|
+ " WHEN (SELECT COUNT(sdc.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole sdc"
|
|
+ " WHERE sdc.ins_deel_key = dsc.ins_deel_key"
|
|
+ " AND sdc.ins_srtcontrole_key = dsc.ins_srtcontrole_key"
|
|
+ " AND sdc.ins_deelsrtcontrole_status = 6"
|
|
+ " AND sdc.ins_scenario_key = 1) > 0"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END hascontroles"
|
|
+ " FROM ins_deelsrtcontrole dsc"
|
|
+ " WHERE ins_deelsrtcontrole_key = (SELECT MAX(id2.ins_deelsrtcontrole_key)" // Laatste record.
|
|
+ " FROM ins_deelsrtcontrole id2"
|
|
+ " WHERE id2.ins_deel_key = dsc.ins_deel_key"
|
|
+ " AND id2.ins_srtcontrole_key = dsc.ins_srtcontrole_key"
|
|
+ " AND id2.ins_scenario_key = dsc.ins_scenario_key)"
|
|
+ " GROUP BY dsc.ins_srtcontrole_key"
|
|
+ " , dsc.ins_deel_key"
|
|
+ " , dsc.ins_scenario_key"
|
|
+ " , dsc.ins_deelsrtcontrole_freezedate"
|
|
+ " , dsc.ins_deelsrtcontrole_freezecost"
|
|
+ " , dsc.ins_deelsrtcontrole_status) c"
|
|
+ " ON e.ins_deel_key = c.ins_deel_key"
|
|
+ " AND e.ins_srtcontrole_key = c.ins_srtcontrole_key"
|
|
+ " AND e.ins_scenario_key = c.ins_scenario_key";
|
|
|
|
var ins_xcp_active_cost = S("ins_xcp_active_cost");
|
|
var costarray = [];
|
|
if (ins_xcp_active_cost & 1) costarray.push("COALESCE(comp.ins_srtcontrole_kosten, 0)");
|
|
if (ins_xcp_active_cost & 2) costarray.push("COALESCE(comp.ins_srtcontrole_kosten2, 0)");
|
|
if (ins_xcp_active_cost & 4) costarray.push("COALESCE(comp.ins_srtcontrole_kosten3, 0)");
|
|
if (ins_xcp_active_cost & 8) costarray.push("COALESCE(comp.ins_srtcontrole_materiaal, 0)");
|
|
var sqlcost = "";
|
|
if (costarray.length > 0)
|
|
sqlcost = "(" + costarray.join(" + ") + ") *";
|
|
|
|
var sql_yearcost =
|
|
"SELECT comp.ins_deel_key"
|
|
+ " , comp.ins_srtcontroledl_xcp_key"
|
|
+ " , comp.ins_srtcontrole_key"
|
|
+ " , comp.ins_srtcontrole_level"
|
|
+ " , comp.ins_srtcontrole_omschrijving"
|
|
+ " , comp.vervangingsjaar"
|
|
+ " , comp.org_nextdate"
|
|
+ " , comp.plandatum"
|
|
+ " , comp.ins_srtcontrole_periode"
|
|
+ " , comp.ins_srtcontrole_opmerking"
|
|
+ " , CASE"
|
|
+ " WHEN comp.vervangingsjaar = comp.org_nextdate AND"
|
|
+ " comp.ins_deelsrtcontrole_status = 2"
|
|
+ " THEN COALESCE(comp.ins_deelsrtcontrole_freezecost, 0)"
|
|
+ " ELSE"
|
|
+ " COALESCE (comp.ins_deel_aantal *"
|
|
+ sqlcost
|
|
+ " (COALESCE(comp.ins_srtcontrole_percentage, 100) / 100) *"
|
|
+ (incbtw
|
|
? " (1 + COALESCE((SELECT fbtw.fin_btwtabelwaarde_perc"
|
|
+ " FROM fin_btwtabelwaarde fbtw"
|
|
+ " WHERE fbtw.fin_btwtabelwaarde_key = comp.fin_btwtabelwaarde_key) / 100"
|
|
+ " , 0)) *"
|
|
: "")
|
|
+ " POWER(" + inflatiefactor + " , comp.vervangingsjaar - EXTRACT(YEAR FROM SYSDATE))"
|
|
+ " , 0)"
|
|
+ " END bedrag"
|
|
+ " , hierlevel"
|
|
+ " , comp.ins_deel_aantal"
|
|
+ " , comp.ins_srtdeel_eenheid"
|
|
+ " , comp.ins_srtcontrole_eind"
|
|
+ " , comp.ins_srtcontrole_afbouwtijd"
|
|
+ " , comp.prs_kostenplaats_key"
|
|
+ " , comp.fin_btwtabelwaarde_key"
|
|
+ " , comp. ins_srtcontroledl_xcp_startdat"
|
|
+ " , comp.ins_srtcontroledl_xcp_eind"
|
|
+ " , comp.ctr_controle_type"
|
|
+ " , comp.ins_scenario_key"
|
|
+ " , comp.hasscenario2"
|
|
+ " , comp.scenario_oms"
|
|
+ " , comp.scenario_aantal"
|
|
+ " , comp.ins_deelsrtcontrole_freezedate"
|
|
+ " , comp.ins_deelsrtcontrole_freezecost"
|
|
+ " , comp.ins_deelsrtcontrole_status"
|
|
+ " , comp.hascontroles"
|
|
+ " FROM (WITH comps (ins_deel_key" // Recursive WITH statement om het volgende vervangingsjaar te vinden (m.vervangingsjaar + m.ins_srtcontrole_periode).
|
|
+ " , ins_srtcontroledl_xcp_key"
|
|
+ " , ins_srtcontrole_key"
|
|
+ " , ins_srtcontrole_level"
|
|
+ " , ins_srtcontrole_omschrijving"
|
|
+ " , ins_srtcontrole_kosten"
|
|
+ " , ins_srtcontrole_kosten2"
|
|
+ " , ins_srtcontrole_kosten3"
|
|
+ " , ins_srtcontrole_materiaal"
|
|
+ " , ins_srtcontrole_periode"
|
|
+ " , ins_srtcontrole_percentage"
|
|
+ " , ins_srtcontrole_opmerking"
|
|
+ " , vervangingsjaar"
|
|
+ " , org_nextdate"
|
|
+ " , plandatum"
|
|
+ " , hierlevel"
|
|
+ " , ins_deel_aantal"
|
|
+ " , ins_srtdeel_eenheid"
|
|
+ " , ins_srtcontrole_eind"
|
|
+ " , ins_srtcontrole_afbouwtijd"
|
|
+ " , prs_kostenplaats_key"
|
|
+ " , fin_btwtabelwaarde_key"
|
|
+ " , ins_srtcontroledl_xcp_startdat"
|
|
+ " , ins_srtcontroledl_xcp_eind"
|
|
+ " , ctr_controle_type"
|
|
+ " , ins_scenario_key"
|
|
+ " , hasscenario2"
|
|
+ " , scenario_oms"
|
|
+ " , scenario_aantal"
|
|
+ " , ins_deelsrtcontrole_freezedate"
|
|
+ " , ins_deelsrtcontrole_freezecost"
|
|
+ " , ins_deelsrtcontrole_status"
|
|
+ " , hascontroles)"
|
|
+ " AS (SELECT ins_deel_key"
|
|
+ " , ins_srtcontroledl_xcp_key"
|
|
+ " , ins_srtcontrole_key"
|
|
+ " , ins_srtcontrole_level"
|
|
+ " , ins_srtcontrole_omschrijving"
|
|
+ " , ins_srtcontrole_kosten"
|
|
+ " , ins_srtcontrole_kosten2"
|
|
+ " , ins_srtcontrole_kosten3"
|
|
+ " , ins_srtcontrole_materiaal"
|
|
+ " , ins_srtcontrole_periode"
|
|
+ " , ins_srtcontrole_percentage"
|
|
+ " , ins_srtcontrole_opmerking"
|
|
+ " , vervangingsjaar"
|
|
+ " , org_nextdate"
|
|
+ " , plandatum"
|
|
+ " , 1 hierlevel"
|
|
+ " , ins_deel_aantal"
|
|
+ " , ins_srtdeel_eenheid"
|
|
+ " , ins_srtcontrole_eind"
|
|
+ " , ins_srtcontrole_afbouwtijd"
|
|
+ " , prs_kostenplaats_key"
|
|
+ " , fin_btwtabelwaarde_key"
|
|
+ " , ins_srtcontroledl_xcp_startdat"
|
|
+ " , ins_srtcontroledl_xcp_eind"
|
|
+ " , ctr_controle_type"
|
|
+ " , ins_scenario_key"
|
|
+ " , hasscenario2"
|
|
+ " , scenario_oms"
|
|
+ " , scenario_aantal"
|
|
+ " , ins_deelsrtcontrole_freezedate"
|
|
+ " , ins_deelsrtcontrole_freezecost"
|
|
+ " , ins_deelsrtcontrole_status"
|
|
+ " , hascontroles"
|
|
+ " FROM (" + sql_componenten + ")"
|
|
+ " WHERE vervangingsjaar IS NOT NULL"
|
|
+ " UNION ALL" // latere jaren
|
|
+ " SELECT m.ins_deel_key"
|
|
+ " , m.ins_srtcontroledl_xcp_key"
|
|
+ " , m.ins_srtcontrole_key"
|
|
+ " , m.ins_srtcontrole_level"
|
|
+ " , m.ins_srtcontrole_omschrijving"
|
|
+ " , m.ins_srtcontrole_kosten"
|
|
+ " , m.ins_srtcontrole_kosten2"
|
|
+ " , m.ins_srtcontrole_kosten3"
|
|
+ " , m.ins_srtcontrole_materiaal"
|
|
+ " , m.ins_srtcontrole_periode"
|
|
+ " , m.ins_srtcontrole_percentage"
|
|
+ " , m.ins_srtcontrole_opmerking"
|
|
+ " , m.vervangingsjaar + m.ins_srtcontrole_periode"
|
|
+ " , m.org_nextdate"
|
|
+ " , m.plandatum"
|
|
+ " , m.hierlevel + 1"
|
|
+ " , m.ins_deel_aantal"
|
|
+ " , m.ins_srtdeel_eenheid"
|
|
+ " , m.ins_srtcontrole_eind"
|
|
+ " , m.ins_srtcontrole_afbouwtijd"
|
|
+ " , m.prs_kostenplaats_key"
|
|
+ " , m.fin_btwtabelwaarde_key"
|
|
+ " , m.ins_srtcontroledl_xcp_startdat"
|
|
+ " , m.ins_srtcontroledl_xcp_eind"
|
|
+ " , m.ctr_controle_type"
|
|
+ " , m.ins_scenario_key"
|
|
+ " , m.hasscenario2"
|
|
+ " , m.scenario_oms"
|
|
+ " , m.scenario_aantal"
|
|
+ " , m.ins_deelsrtcontrole_freezedate"
|
|
+ " , m.ins_deelsrtcontrole_freezecost"
|
|
+ " , m.ins_deelsrtcontrole_status"
|
|
+ " , CASE"
|
|
+ " WHEN (SELECT COUNT(sdc.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole sdc"
|
|
+ " WHERE sdc.ins_deel_key = m.ins_deel_key"
|
|
+ " AND sdc.ins_srtcontrole_key = m.ins_srtcontrole_key"
|
|
+ " AND sdc.ins_deelsrtcontrole_status = 6"
|
|
+ " AND sdc.ins_scenario_key = 1) > 0"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END hascontroles"
|
|
+ " FROM comps m"
|
|
+ " WHERE (m.vervangingsjaar + m.ins_srtcontrole_periode <= " + toyear + "))"
|
|
+ " SELECT *"
|
|
+ " FROM comps"
|
|
+ " ) comp";
|
|
|
|
var keyColumn = "";
|
|
switch (groupby)
|
|
{
|
|
case 1: keyColumn = "d.alg_district_key";
|
|
break;
|
|
case 2: keyColumn = "l.alg_locatie_key";
|
|
break;
|
|
case 3: keyColumn = "g.alg_gebouw_key";
|
|
break;
|
|
case 4: keyColumn = "dl.ins_discipline_key";
|
|
break;
|
|
case 5: keyColumn = "isg.ins_srtgroep_key";
|
|
break;
|
|
case 6: keyColumn = "isd.ins_srtdeel_key";
|
|
break;
|
|
case 7:
|
|
case 8: keyColumn = "dl.ins_deel_key";
|
|
break;
|
|
}
|
|
|
|
var sql_cost_verval = "SELECT d.alg_district_key"
|
|
+ " , d.alg_district_omschrijving"
|
|
+ " , l.alg_locatie_omschrijving"
|
|
+ " , l.alg_locatie_key"
|
|
+ " , g.alg_gebouw_omschrijving"
|
|
+ " , g.alg_gebouw_key"
|
|
+ " , dl.ins_deel_omschrijving"
|
|
+ " , dl.ins_deel_mjb_score1"
|
|
+ " , isd.ins_srtdeel_mjb_grensscore1"
|
|
+ " , dl.ins_deel_mjb_score2"
|
|
+ " , l.alg_locatie_mjb_score1"
|
|
+ " , g.alg_gebouw_mjb_score1"
|
|
+ " , cy.ins_deel_aantal"
|
|
+ " , cy.ins_srtdeel_eenheid"
|
|
+ " , dl.ins_deel_opmerking"
|
|
+ " , dd.ins_discipline_omschrijving"
|
|
+ " , dd.ins_discipline_key"
|
|
+ " , isg.ins_srtgroep_omschrijving"
|
|
+ " , isd.ins_srtdeel_omschrijving"
|
|
+ " , cy.ins_srtcontrole_omschrijving"
|
|
+ " , cy.ins_deel_key"
|
|
+ " , " + keyColumn + " keyColumn"
|
|
+ " , cy.ins_srtcontroledl_xcp_key"
|
|
+ " , cy.ins_srtcontrole_key"
|
|
+ " , cy.ins_srtcontrole_periode"
|
|
+ " , cy.ins_srtcontrole_opmerking"
|
|
+ " , cy.ins_srtcontrole_level"
|
|
+ " , g.alg_gebouw_vervaldatum"
|
|
+ " , dl.ins_deel_vervaldatum"
|
|
+ " , cy.ins_srtcontroledl_xcp_startdat"
|
|
+ " , cy.ins_srtcontroledl_xcp_eind"
|
|
+ " , cy.ins_srtcontrole_eind"
|
|
+ " , EXTRACT(YEAR FROM LEAST(COALESCE(cy.ins_srtcontroledl_xcp_startdat"
|
|
+ " , dl.ins_deel_aanmaak)"
|
|
+ " , COALESCE(dl.ins_deel_aanmaak"
|
|
+ " , cy.ins_srtcontroledl_xcp_startdat))"
|
|
+ " ) startjaar"
|
|
+ " , CASE"
|
|
+ " WHEN cy.ins_srtcontroledl_xcp_startdat IS NOT NULL AND dl.ins_deel_aanmaak IS NULL"
|
|
+ " THEN 'S'" // Startdatum
|
|
+ " WHEN cy.ins_srtcontroledl_xcp_startdat IS NULL AND dl.ins_deel_aanmaak IS NOT NULL"
|
|
+ " THEN 'A'" // Aanmaakdatum/Registratiedatum
|
|
+ " WHEN cy.ins_srtcontroledl_xcp_startdat IS NOT NULL AND dl.ins_deel_aanmaak IS NOT NULL"
|
|
+ " THEN"
|
|
+ " CASE"
|
|
+ " WHEN EXTRACT(YEAR FROM cy.ins_srtcontroledl_xcp_startdat) >= EXTRACT(YEAR FROM dl.ins_deel_aanmaak)"
|
|
+ " THEN 'S'" // Startdatum
|
|
+ " ELSE 'A'" // Aanmaakdatum/Registratiedatum
|
|
+ " END"
|
|
+ " ELSE NULL"
|
|
+ " END starttype"
|
|
+ " , EXTRACT(YEAR FROM LEAST(COALESCE(g.alg_gebouw_vervaldatum"
|
|
+ " , dl.ins_deel_vervaldatum"
|
|
+ " , COALESCE(cy.ins_srtcontroledl_xcp_eind, cy.ins_srtcontrole_eind))"
|
|
+ " , COALESCE(COALESCE(cy.ins_srtcontroledl_xcp_eind, cy.ins_srtcontrole_eind)"
|
|
+ " , g.alg_gebouw_vervaldatum"
|
|
+ " , dl.ins_deel_vervaldatum)"
|
|
+ " , COALESCE(dl.ins_deel_vervaldatum"
|
|
+ " , COALESCE(cy.ins_srtcontroledl_xcp_eind, cy.ins_srtcontrole_eind)"
|
|
+ " , g.alg_gebouw_vervaldatum))"
|
|
+ " ) vervaljaar"
|
|
+ " , vervangingsjaar"
|
|
+ " , org_nextdate"
|
|
+ " , EXTRACT(YEAR FROM plandatum) planjaar"
|
|
+ " , ins_srtcontrole_afbouwtijd afbouwtijd"
|
|
+ " , cy.prs_kostenplaats_key"
|
|
+ " , bedrag"
|
|
+ " , cy.ctr_controle_type"
|
|
+ " , cy.ins_scenario_key"
|
|
+ " , cy.hasscenario2"
|
|
+ " , cy.scenario_oms"
|
|
+ " , cy.scenario_aantal"
|
|
+ " , cy.ins_deelsrtcontrole_freezedate"
|
|
+ " , cy.ins_deelsrtcontrole_freezecost"
|
|
+ " , cy.ins_deelsrtcontrole_status"
|
|
+ " , cy.hascontroles"
|
|
+ " FROM (" + sql_yearcost + ") cy"
|
|
+ " , ins_deel dl" // I.v.m. ORA-03113 fout: ins_v_aanwezigdeel vervangen door ins_deel en verder uitgeschreven (FSN#51212).
|
|
+ " , ins_srtdeel isd"
|
|
+ " , ins_srtgroep isg"
|
|
+ " , ins_discipline dd"
|
|
+ " , alg_district d"
|
|
+ " , alg_locatie l"
|
|
+ " , alg_gebouw g"
|
|
+ " , alg_verdieping v"
|
|
+ " , alg_ruimte r"
|
|
+ " WHERE cy.ins_deel_key = dl.ins_deel_key"
|
|
+ " AND dl.ins_deel_verwijder IS NULL"
|
|
+ " AND dl.ins_deel_parent_key IS NULL"
|
|
+ " AND dl.ins_srtdeel_key = isd.ins_srtdeel_key"
|
|
+ " AND isd.ins_srtgroep_key = isg.ins_srtgroep_key"
|
|
+ " AND isg.ins_discipline_key = dd.ins_discipline_key"
|
|
+ " AND dl.ins_alg_ruimte_key = r.alg_ruimte_key"
|
|
+ " AND r.alg_verdieping_key = v.alg_verdieping_key"
|
|
+ " AND v.alg_gebouw_key = g.alg_gebouw_key"
|
|
+ " AND g.alg_locatie_key = l.alg_locatie_key"
|
|
+ " AND d.alg_district_key = l.alg_district_key";
|
|
|
|
if (keys != null && keys.length > 0 && niveau != null && niveau > 0 && (freeze || finish))
|
|
{
|
|
switch (niveau)
|
|
{
|
|
case 1: sql_cost_verval += " AND d.alg_district_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
case 2: sql_cost_verval += " AND g.alg_locatie_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
case 3: sql_cost_verval += " AND g.alg_gebouw_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
case 4: sql_cost_verval += " AND dl.ins_discipline_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
case 5: sql_cost_verval += " AND isg.ins_srtgroep_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
case 6: sql_cost_verval += " AND isd.ins_srtdeel_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
case 7: sql_cost_verval += " AND dl.ins_deel_key IN (" + keys.join(",") + ")";
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (deel)
|
|
sql_cost_verval += " AND dl.ins_deel_upper LIKE " + safe.quoted_sql_wild("%" + deel + "%");
|
|
|
|
if (bld_key > 0)
|
|
sql_cost_verval += " AND g.alg_gebouw_key = " + bld_key;
|
|
|
|
var sql_cost = "SELECT cv.alg_district_key"
|
|
+ " , cv.alg_district_omschrijving"
|
|
+ " , cv.alg_locatie_omschrijving"
|
|
+ " , cv.alg_locatie_key"
|
|
+ " , cv.alg_gebouw_omschrijving"
|
|
+ " , cv.alg_gebouw_key"
|
|
+ " , cv.ins_deel_omschrijving"
|
|
+ " , cv.ins_deel_mjb_score1"
|
|
+ " , cv.ins_deel_mjb_score2"
|
|
+ " , cv.ins_srtdeel_mjb_grensscore1"
|
|
+ " , cv.alg_locatie_mjb_score1"
|
|
+ " , cv.alg_gebouw_mjb_score1"
|
|
+ " , cv.ins_deel_aantal"
|
|
+ " , cv.ins_srtdeel_eenheid"
|
|
+ " , cv.ins_deel_opmerking"
|
|
+ " , cv.ins_discipline_omschrijving"
|
|
+ " , cv.ins_discipline_key"
|
|
+ " , cv.ins_srtgroep_omschrijving"
|
|
+ " , cv.ins_srtdeel_omschrijving"
|
|
+ " , cv.ins_srtcontrole_omschrijving"
|
|
+ " , cv.ins_deel_key"
|
|
+ " , cv.keyColumn"
|
|
+ " , cv.ins_srtcontroledl_xcp_key"
|
|
+ " , cv.ins_srtcontrole_key"
|
|
+ " , cv.ins_srtcontrole_periode"
|
|
+ " , cv.ins_srtcontrole_opmerking"
|
|
+ " , cv.ins_srtcontrole_level"
|
|
+ " , cv.startjaar"
|
|
+ " , cv.starttype"
|
|
+ " , cv.vervaljaar"
|
|
+ " , cv.vervangingsjaar"
|
|
+ (fulldetails?" , org_nextdate" // Eerstaankomende inspectie: 1-ste dit jaar of in de toekomst.
|
|
:" , NULL org_nextdate")
|
|
+ " , cv.planjaar"
|
|
+ " , cv.afbouwtijd"
|
|
+ " , cv.ins_srtcontroledl_xcp_startdat startdatum"
|
|
+ " , (SELECT " + S("prs_kpn_string")
|
|
+ " FROM prs_kostenplaats k"
|
|
+ " WHERE k.prs_kostenplaats_key = CV.prs_kostenplaats_key) kostenplaats"
|
|
+ " , CASE"
|
|
+ " WHEN (SELECT idsc.ins_deelsrtcontrole_key"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " WHERE idsc.ins_deel_key = cv.ins_deel_key"
|
|
+ " AND idsc.ins_srtcontrole_key = cv.ins_srtcontrole_key"
|
|
+ " AND idsc.ins_deelsrtcontrole_status IN (0)"
|
|
+ " AND idsc.ins_scenario_key = cv.ins_scenario_key) IS NOT NULL"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END isPlanned"
|
|
+ " , CASE"
|
|
+ " WHEN (SELECT idsc.ins_deelsrtcontrole_key"
|
|
+ " FROM ins_deelsrtcontrole idsc"
|
|
+ " WHERE idsc.ins_deel_key = cv.ins_deel_key"
|
|
+ " AND idsc.ins_srtcontrole_key = cv.ins_srtcontrole_key"
|
|
+ " AND idsc.ins_deelsrtcontrole_status IN (2, 5)"
|
|
+ " AND idsc.ins_scenario_key = cv.ins_scenario_key) IS NOT NULL"
|
|
+ " THEN 0"
|
|
+ " ELSE 1"
|
|
+ " END canBePlanned"
|
|
+ " , COALESCE((SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = cv.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = cv.ins_srtcontrole_key"
|
|
+ " AND (idsc2.ins_scenario_key = cv.ins_scenario_key))"
|
|
+ " , -1) ins_deelsrtcontrole_key"
|
|
+ " , cv.bedrag AS orgbedrag"
|
|
// Als er een andere inspectie is met een lagere ins_srtcontrole_level in hetzelfde jaar dan springt ons bedrag op 0
|
|
// Dit gebeurt o.a. ook als: 1) het object vervallen is of
|
|
// 2) de startdatum of de registratiedatum in de toekomst ligt.
|
|
// Als de registratiedatum in de toekomst ligt en de startdatum eventueel ook dan geldt het volgende.
|
|
// Voor Controle(1): Eerste inspectie tonen op MAX(startdatum, registratiedatum) van het object.
|
|
// Voor Vervanging(2) of Certificering(3):
|
|
// a) Als registratiedatum het verst in de toekomst ligt: Eerste inspectie tonen op 1 periode verder dan de registratiedatum.
|
|
// b) Als de startdatum het verst in de toekomst ligt: Eerste inspectie tonen op de startdatum.
|
|
+ " , CASE WHEN MIN(cv.ins_srtcontrole_level) KEEP (DENSE_RANK FIRST ORDER BY cv.ins_srtcontrole_level) "
|
|
+ " OVER (PARTITION BY cv.ins_deel_key, cv.vervangingsjaar, cv.ins_scenario_key) < cv.ins_srtcontrole_level"
|
|
+ " OR"
|
|
+ " (cv.vervaljaar IS NOT NULL AND (cv.vervaljaar - COALESCE(cv.afbouwtijd, 0)) < cv.vervangingsjaar)"
|
|
+ " OR"
|
|
+ " (cv.startjaar IS NOT NULL AND cv.startjaar >= cv.vervangingsjaar AND "
|
|
+ " (cv.starttype = 'S' OR (cv.starttype = 'A' AND ctr_controle_type = 1)))"
|
|
+ " OR"
|
|
+ " (cv.startjaar IS NOT NULL AND (CV.startjaar + ins_srtcontrole_periode) > cv.vervangingsjaar AND"
|
|
+ " cv.starttype = 'A' AND ctr_controle_type != 1 AND"
|
|
+ " ((cv.planjaar IS NULL) OR (cv.planjaar IS NOT NULL AND cv.planjaar > cv.vervangingsjaar)))"
|
|
+ " THEN 0 "
|
|
+ " ELSE cv.bedrag "
|
|
+ " END bedrag"
|
|
+ " , cv.ctr_controle_type"
|
|
+ " , cv.ins_scenario_key"
|
|
+ " , cv.hasscenario2"
|
|
+ " , cv.scenario_oms"
|
|
+ " , cv.scenario_aantal"
|
|
+ " , cv.ins_deelsrtcontrole_freezedate"
|
|
+ " , cv.ins_deelsrtcontrole_freezecost"
|
|
+ " , cv.ins_deelsrtcontrole_status"
|
|
+ " , cv.hascontroles"
|
|
+ " FROM (" + sql_cost_verval + ") cv";
|
|
|
|
var sqlArray = [];
|
|
var sql_cost_where = "";
|
|
if (mjbMoved) // Aangepast.
|
|
{
|
|
sqlArray.push("isPlanned = 1");
|
|
}
|
|
if (mjbFreezed) // In behandeling (Bevroren).
|
|
{
|
|
sqlArray.push("ins_deelsrtcontrole_freezedate IS NOT NULL AND ins_deelsrtcontrole_status = 2");
|
|
}
|
|
if (mjbXcped) // Aangepast.
|
|
{
|
|
sqlArray.push("ins_srtcontroledl_xcp_key IS NOT NULL AND ins_scenario_key = 1");
|
|
}
|
|
|
|
if (sqlArray.length)
|
|
sql_cost_where = " WHERE ((" + sqlArray.join(") OR (") + "))";
|
|
|
|
if (!fulldetails)
|
|
{
|
|
var fields = [];
|
|
if (groupby == 1 || groupby == 2 || groupby == 3)
|
|
{
|
|
fields.push("alg_district_omschrijving");
|
|
if (groupby == 2 || groupby == 3)
|
|
{
|
|
if (groupby == 2)
|
|
fields.push("alg_locatie_mjb_score1");
|
|
fields.push("alg_locatie_key");
|
|
fields.push("alg_locatie_omschrijving");
|
|
if (groupby == 3)
|
|
{
|
|
fields.push("alg_gebouw_key");
|
|
fields.push("alg_gebouw_omschrijving");
|
|
fields.push("alg_gebouw_mjb_score1");
|
|
}
|
|
}
|
|
}
|
|
if (groupby >= 4 && groupby <= 7)
|
|
fields.push("ins_discipline_omschrijving");
|
|
if (groupby >= 5 && groupby <= 7)
|
|
fields.push("ins_srtgroep_omschrijving");
|
|
if (groupby == 6 || groupby == 7)
|
|
fields.push("ins_srtdeel_omschrijving");
|
|
if (groupby == 7)
|
|
fields.push("ins_deel_omschrijving");
|
|
if (groupby >= 7) // bij omschrijving hoort ook aantal met eenheid.
|
|
{
|
|
fields.push("ins_deel_aantal");
|
|
fields.push("ins_srtdeel_eenheid");
|
|
fields.push("ins_deel_mjb_score1");
|
|
fields.push("ins_srtdeel_mjb_grensscore1");
|
|
fields.push("ins_deel_mjb_score2");
|
|
}
|
|
|
|
var sql_cost = "SELECT " + fields.join(", ")
|
|
+ " , keyColumn"
|
|
+ (keyColumn == "dl.ins_deel_key"
|
|
? " , ins_deel_opmerking"
|
|
: "")
|
|
+ " , vervangingsjaar"
|
|
+ " , SUM(bedrag) bedrag"
|
|
+ " , SUM(orgbedrag) orgbedrag"
|
|
+ " , hasscenario2"
|
|
+ " , ins_scenario_key"
|
|
+ " FROM (" + sql_cost + ")"
|
|
+ sql_cost_where
|
|
+ " GROUP BY " + fields.join(", ")
|
|
+ " , keyColumn"
|
|
+ (keyColumn == "dl.ins_deel_key"
|
|
? " , ins_deel_opmerking"
|
|
: "")
|
|
+ " , vervangingsjaar"
|
|
+ " , hasscenario2"
|
|
+ " , ins_scenario_key";
|
|
}
|
|
|
|
var sql = "SELECT *"
|
|
+ " FROM ("
|
|
+ sql_cost
|
|
+ ") PIVOT (SUM(bedrag), SUM(orgbedrag) AS orgbedrag "
|
|
+ " FOR vervangingsjaar IN (" + jaren.join(",") + ") )";
|
|
|
|
if (scenario > 1)
|
|
{
|
|
if (!actsit)
|
|
sql += " WHERE ins_scenario_key IN (" + scenario + ") AND hasscenario2 = 1";
|
|
else
|
|
sql += " WHERE ins_scenario_key IN (" + scenario + ") OR (hasscenario2 = 0 AND ins_scenario_key = 1)";
|
|
}
|
|
else
|
|
{
|
|
// actsit hier geen invloed.
|
|
sql += " WHERE ins_scenario_key = 1";
|
|
}
|
|
|
|
// Conditie score.
|
|
// Niet gemeten objecten doen wel mee in dit filter. Deze objecten worden dus niet getoond als er een waarde is ingevuld.
|
|
var mjb_score = "ins_deel_mjb_score1";
|
|
if (groupby == 2)
|
|
mjb_score = "alg_locatie_mjb_score1";
|
|
else if (groupby == 3)
|
|
mjb_score = "alg_gebouw_mjb_score1";
|
|
|
|
if (fitness_score1_from > 0)
|
|
sql += " AND " + mjb_score + " >= " + fitness_score1_from;
|
|
if (fitness_score1_through > 0)
|
|
sql += " AND " + mjb_score + " <= " + fitness_score1_through;
|
|
|
|
// Negatieve afwijking (=dus slechter) van de conditiescore (ins_deel_mjb_score1) in hele getallen t.o.v. de norm (ins_srtdeel_mjb_grensscore1) .
|
|
// Wanneer een element NIET is gemeten (conditiemeting is niet geweest) dan is ins_deel_score1 LEEG,
|
|
// Dan doet het elelement niet mee in het filter "afwijking". Want er is dan per defintie geen afwijking, omdat dit niet bekend is.
|
|
var fitness_score1_neg = [];
|
|
if (fitness_score1_from_neg > 0 || fitness_score1_through_neg > 0)
|
|
{
|
|
if (fitness_score1_from_neg > 0)
|
|
fitness_score1_neg.push("ins_deel_mjb_score1 >= (ins_srtdeel_mjb_grensscore1 + " + fitness_score1_from_neg + ")");
|
|
if (fitness_score1_through_neg > 0)
|
|
{
|
|
fitness_score1_neg.push("ins_deel_mjb_score1 <= (ins_srtdeel_mjb_grensscore1 + " + fitness_score1_through_neg + ")");
|
|
if (fitness_score1_from_neg == -1)
|
|
fitness_score1_neg.push("ins_deel_mjb_score1 > ins_srtdeel_mjb_grensscore1");
|
|
}
|
|
sql += "AND ((" + fitness_score1_neg.join(" AND ") + ") OR ins_srtdeel_mjb_grensscore1 IS NULL)"
|
|
}
|
|
|
|
// Positieve afwijking (=dus beter) van de conditiescore (ins_deel_mjb_score1) in hele getallen t.o.v. de norm (ins_srtdeel_mjb_grensscore1) .
|
|
// Wanneer een element NIET is gemeten (conditiemeting is niet geweest) dan is ins_deel_score1 LEEG,
|
|
// Dan doet het elelement niet mee in het filter "afwijking". Want er is dan per defintie geen afwijking, omdat dit niet bekend is.
|
|
var fitness_score1_pos = [];
|
|
if (fitness_score1_from_pos > 0 || fitness_score1_through_pos > 0)
|
|
{
|
|
if (fitness_score1_from_pos > 0)
|
|
fitness_score1_pos.push("ins_deel_mjb_score1 <= (ins_srtdeel_mjb_grensscore1 - " + fitness_score1_from_pos + ")");
|
|
if (fitness_score1_through_pos > 0)
|
|
{
|
|
fitness_score1_pos.push("ins_deel_mjb_score1 >= (ins_srtdeel_mjb_grensscore1 - " + fitness_score1_through_pos + ")");
|
|
if (fitness_score1_from_pos == -1)
|
|
fitness_score1_pos.push("ins_deel_mjb_score1 < ins_srtdeel_mjb_grensscore1");
|
|
}
|
|
sql += "AND ((" + fitness_score1_pos.join(" AND ") + ") OR ins_srtdeel_mjb_grensscore1 IS NULL)"
|
|
}
|
|
|
|
// Prioriteitsscore.
|
|
// Niet gemeten objecten doen wel mee in dit filter. Deze objecten worden dus niet getoond als er een waarde is ingevuld.
|
|
if (priority_score2_from > 0)
|
|
sql += " AND ins_deel_mjb_score2 >= " + priority_score2_from;
|
|
if (priority_score2_through > 0)
|
|
sql += " AND ins_deel_mjb_score2 <= " + priority_score2_through;
|
|
|
|
if (fulldetails && sqlArray.length)
|
|
sql += " AND ((" + sqlArray.join(") OR (") + "))";
|
|
|
|
sql += " ORDER BY 1";
|
|
for (var i = 2; i <= groupby; i++)
|
|
{
|
|
sql += "," + String(i)
|
|
}
|
|
|
|
// Bulkactie accorderen (freeze) of voltooien/afronden (finish).
|
|
// Ik moet nog de juiste insert waarden ophalen voor alle objecten die de sql oplevert.
|
|
if (niveau >= 1 && niveau <= 7 && (freeze || finish))
|
|
{ // Accorderen (Freeze) of Voltooien/Afronden (Finish).
|
|
if (freeze)
|
|
{
|
|
var mjblist_sql_select = "SELECT xcp.ins_deel_key"
|
|
+ " , xcp.ins_srtcontrole_key"
|
|
+ " , CASE"
|
|
+ " WHEN result.ins_deelsrtcontrole_status IS NOT NULL"
|
|
+ " THEN (SELECT ins.nextcyclusdate (xcp.ins_deel_key, xcp.ins_srtcontrole_key, 1, 1) FROM DUAL)"
|
|
+ " ELSE NULL"
|
|
+ " END nextdate"
|
|
+ " , result.ins_deelsrtcontrole_status"
|
|
+ " , result.\"" + mjb_freeze_year + "\" freeze_bedrag"
|
|
+ " , CASE"
|
|
+ " WHEN result.\"" + mjb_freeze_year + "\" = 0 AND result.\"" + mjb_freeze_year + "_ORGBEDRAG\" IS NOT NULL AND result.\"" + mjb_freeze_year + "_ORGBEDRAG\" > 0"
|
|
+ " THEN " + safe.quoted_sql(L("lcl_mjb_performed_high"))
|
|
+ " ELSE ''"
|
|
+ " END opm_has_higherprio"; // Opmerking als het een hogere prio heeft (has_higherprio)
|
|
}
|
|
else // finish
|
|
{
|
|
if (getsumtypes)
|
|
{
|
|
var mjblist_sql_select = "SELECT SUM(CASE"
|
|
+ " WHEN xcp.ctr_controle_type = 1"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END) sumtype1"
|
|
+ " , SUM(CASE"
|
|
+ " WHEN xcp.ctr_controle_type = 2"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END) sumtype2"
|
|
+ " , SUM(CASE"
|
|
+ " WHEN xcp.ctr_controle_type = 3"
|
|
+ " THEN 1"
|
|
+ " ELSE 0"
|
|
+ " END) sumtype3";
|
|
}
|
|
else
|
|
{
|
|
var mjblist_sql_select = "SELECT xcp.ins_deel_key"
|
|
+ " , xcp.ins_srtcontrole_key"
|
|
+ " , result.ctr_controle_type"
|
|
+ " , CASE"
|
|
+ " WHEN (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key"
|
|
+ " AND idsc2.ins_deelsrtcontrole_status = 6) IS NOT NULL" // Er is al een inspectie geweest.
|
|
+ " THEN (SELECT ins.nextcyclusdate (xcp.ins_deel_key, xcp.ins_srtcontrole_key, 1, 1) FROM DUAL)"
|
|
+ " ELSE SYSDATE" // Er is nog geen inspectie geweest. De org date wordt nu.
|
|
+ " END nextdate"
|
|
+ " , (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key) ins_deelsrtcontrole_key"
|
|
+ " , (SELECT cm.ins_controlemode_oms"
|
|
+ " FROM ins_controlemode cm"
|
|
+ " WHERE cm.ins_controlemode_key IN (" + sel_controlemode123.join(",") + ")"
|
|
+ " AND cm.ins_srtcontrole_type = result.ctr_controle_type) cm_oms"
|
|
+ " , (SELECT cd.ins_discipline_omschrijving"
|
|
+ " FROM ctr_discipline cd"
|
|
+ " WHERE cd.ins_discipline_key = xcp.ctr_discipline_key) ctr_disc_oms"
|
|
+ " , (SELECT idsc2.ins_deelsrtcontrole_opmerking"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE ins_deelsrtcontrole_key = (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key)) ins_deelsrtcontrole_opmerking";
|
|
}
|
|
}
|
|
|
|
|
|
var mjblist_sql = mjblist_sql_select
|
|
+ " FROM ins_v_defined_inspect_xcp xcp"
|
|
+ " , ins_deel dl" // I.v.m. ORA-03113 fout: ins_v_aanwezigdeel vervangen door ins_deel en verder uitgeschreven (FSN#51212).
|
|
+ " , ins_srtdeel isd"
|
|
+ " , ins_srtgroep isg"
|
|
+ " , ins_discipline dd"
|
|
+ " , alg_district d"
|
|
+ " , alg_locatie l"
|
|
+ " , alg_gebouw g"
|
|
+ " , alg_verdieping v"
|
|
+ " , alg_ruimte r"
|
|
+ " , (" + sql + ") result"
|
|
+ " WHERE xcp.ins_deel_key = dl.ins_deel_key"
|
|
+ " AND dl.ins_deel_verwijder IS NULL"
|
|
+ " AND dl.ins_deel_parent_key IS NULL"
|
|
+ " AND dl.ins_srtdeel_key = isd.ins_srtdeel_key"
|
|
+ " AND isd.ins_srtgroep_key = isg.ins_srtgroep_key"
|
|
+ " AND isg.ins_discipline_key = dd.ins_discipline_key"
|
|
+ " AND dl.ins_alg_ruimte_key = r.alg_ruimte_key"
|
|
+ " AND r.alg_verdieping_key = v.alg_verdieping_key"
|
|
+ " AND v.alg_gebouw_key = g.alg_gebouw_key"
|
|
+ " AND g.alg_locatie_key = l.alg_locatie_key"
|
|
+ " AND d.alg_district_key = l.alg_district_key"
|
|
+ " AND xcp.ins_deel_key = result.ins_deel_key"
|
|
+ " AND xcp.ins_srtcontrole_key = result.ins_srtcontrole_key"
|
|
// Inspectie mag niet op dezelfde dag plaatsvinden
|
|
// Als er nog geen inspectie is geweest neem dan gisteren (sysdate - 1).
|
|
+ " AND COALESCE((SELECT TRUNC(idsc2.ins_deelsrtcontrole_datum)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE ins_deelsrtcontrole_key = (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key"
|
|
+ " AND idsc2.ins_deelsrtcontrole_status = 6)), (TRUNC(SYSDATE-1))) != TRUNC(SYSDATE)"
|
|
// Autorisatie controleren i.p.v. canInspStartReq (Accorderen (Freeze)) en canInspFinishReq (Voltooien/Afronden (Finish)):
|
|
// 0) invoerAfterNext is voor mjob (interval modus) altijd waar.
|
|
// 1) Alleen voor Accorderen (Freeze): niet vervallen.
|
|
// 2) Freeze: status <= 0 of status == 6
|
|
// Finish: status == 2
|
|
// 3) actief object
|
|
// 4) hasCTRwrite
|
|
// 5) Freeze: bij instelling "Actieve acties" het vinkje "Starten" aangevinkt.
|
|
// Finish: bij instelling "Actieve acties" het vinkje "Afronden" aangevinkt.
|
|
// 6) geen scenario (scenario_key is 1)
|
|
// 7) ismjob
|
|
// 8) isFreezeYear
|
|
// 9) readuse rechten.
|
|
+ (freeze
|
|
? " AND (xcp.ins_srtcontroledl_xcp_eind IS NULL OR xcp.ins_srtcontroledl_xcp_eind >= SYSDATE)" // 1) Freeze: Niet vervallen.
|
|
: "") // Finish: Maakt niet uit.
|
|
+ (freeze
|
|
? " AND (EXISTS" // 2) Freeze: Geen controles of laatste controle status 0 of 6.
|
|
+ " (SELECT idsc1.ins_deelsrtcontrole_status"
|
|
+ " FROM ins_deelsrtcontrole idsc1"
|
|
+ " WHERE idsc1.ins_deelsrtcontrole_key = (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key)"
|
|
+ " AND idsc1.ins_deelsrtcontrole_status IN (0, 6))"
|
|
+ " OR NOT EXISTS"
|
|
+ " (SELECT idsc2.ins_deelsrtcontrole_key"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key))"
|
|
: " AND EXISTS" // Finish: Laatste controle status 2.
|
|
+ " (SELECT idsc1.ins_deelsrtcontrole_status"
|
|
+ " FROM ins_deelsrtcontrole idsc1"
|
|
+ " WHERE idsc1.ins_deelsrtcontrole_key = (SELECT MAX(idsc2.ins_deelsrtcontrole_key)"
|
|
+ " FROM ins_deelsrtcontrole idsc2"
|
|
+ " WHERE idsc2.ins_deel_key = xcp.ins_deel_key"
|
|
+ " AND idsc2.ins_srtcontrole_key = xcp.ins_srtcontrole_key"
|
|
+ " AND idsc2.ins_scenario_key = xcp.ins_scenario_key)"
|
|
+ " AND idsc1.ins_deelsrtcontrole_status IN (2))")
|
|
+ " AND ins_deel_actief = 1" // 3) Actief object.
|
|
+ " AND xcp.ctr_discipline_key IN (SELECT w.ins_discipline_key" // 4) hasCTRwrite.
|
|
+ " FROM fac_v_webgebruiker w"
|
|
+ " , fac_functie f"
|
|
+ " WHERE w.fac_functie_key = f.fac_functie_key"
|
|
+ " AND f.fac_functie_code = 'WEB_CTRUSE'"
|
|
+ " AND w.fac_gebruiker_prs_level_write < 9"
|
|
+ " AND w.fac_gebruiker_alg_level_write < 9"
|
|
+ " AND w.prs_perslid_key = " + user_key + ")"
|
|
+ (freeze
|
|
? " AND BITAND(xcp.ins_srtcontrole_options, 2) = 2" // 5) Freeze: Het vinkje "Starten" aangevinkt.
|
|
: " AND BITAND(xcp.ins_srtcontrole_options, 8) = 8") // Finish: Het vinkje "Afronden" aangevinkt.
|
|
+ " AND xcp.ins_scenario_key = 1" // 6) Geen scenario.
|
|
+ " AND xcp.ctr_ismjob = 1" // 7) ismjob.
|
|
+ " AND result.\"" + mjb_freeze_year + "\" IS NOT NULL"; // 8) isFreezeYear, bedrag in mjb_freeze_year is niet NULL.
|
|
|
|
sql = discxalg3d(mjblist_sql, // 9) 3D-readuse rechten.
|
|
"dd.ins_discipline_key",
|
|
"d.alg_regio_key",
|
|
"d.alg_district_key",
|
|
"l.alg_locatie_key",
|
|
"g.alg_gebouw_key",
|
|
"v.alg_verdieping_key",
|
|
"r.alg_ruimte_key",
|
|
"WEB_INSUSE", //autfunction,
|
|
"",
|
|
false); // forwrite => read
|
|
|
|
sql += " ORDER BY xcp.ins_deel_key"
|
|
+ " , xcp.ins_srtcontrole_key";
|
|
}
|
|
return sql;
|
|
},
|
|
|
|
saveXcp:
|
|
function (ins_key, srtcontrole_key, params)
|
|
{
|
|
var xcp_key = params.xcp_key;
|
|
var eenheid = params.eenheid;
|
|
var periode = params.periode;
|
|
var aantal = params.aantal;
|
|
var aanteh = params.aanteh;
|
|
var kosten1 = params.kosten1;
|
|
var kosten2 = params.kosten2;
|
|
var kosten3 = params.kosten3;
|
|
var uren = params.uren;
|
|
var materiaal = params.materiaal;
|
|
var perc = params.perc;
|
|
var groep = params.groep;
|
|
var startdatum = params.startdatum;
|
|
var vervaldatum = params.vervaldatum;
|
|
var opmerk = params.opmerk;
|
|
var bits = params.bits;
|
|
var isScenario = params.isScenario;
|
|
var scen_key = params.scen_key; // Doorvoeren scenario.
|
|
var commit = params.commit; // Doorvoeren scenario.
|
|
|
|
// Ophalen standaard waarden.
|
|
var sql = "SELECT d.ins_deel_aantal"
|
|
+ " , sd.ins_srtdeel_eenheid"
|
|
+ " , isc.ins_srtcontrole_eenheid"
|
|
+ " , isc.ins_srtcontrole_periode"
|
|
+ " , isc.ins_srtcontrole_bits"
|
|
+ " , isc.ins_srtcontrole_kosten"
|
|
+ " , isc.ins_srtcontrole_kosten2"
|
|
+ " , isc.ins_srtcontrole_kosten3"
|
|
+ " , isc.ins_srtcontrole_uren"
|
|
+ " , isc.ins_srtcontrole_materiaal"
|
|
+ " , isc.ins_srtcontrole_percentage"
|
|
+ " , ins_srtcontrole_groep"
|
|
+ " , isc.ins_srtcontrole_eind"
|
|
+ " , isc.ins_srtcontrole_opmerking"
|
|
+ " , isc.ctr_discipline_key"
|
|
+ " , isc.ins_srtcontrole_omschrijving"
|
|
+ " , cd.ins_discipline_omschrijving"
|
|
+ " , (SELECT xcp1.ins_srtcontroledl_xcp_key"
|
|
+ " FROM ins_srtcontroledl_xcp xcp1"
|
|
+ " WHERE xcp1.ins_deel_key = d.ins_deel_key"
|
|
+ " AND xcp1.ins_srtcontrole_key = isc.ins_srtcontrole_key"
|
|
+ " AND xcp1.ins_scenario_key = isc.ins_scenario_key) ins_srtcontroledl_xcp_key"
|
|
+ " FROM ins_srtcontrole isc"
|
|
+ " , ins_deel d"
|
|
+ " , ins_srtdeel sd"
|
|
+ " , ctr_v_aanwezigdiscipline cd"
|
|
+ " WHERE sd.ins_srtdeel_key = d.ins_srtdeel_key"
|
|
+ " AND (isc.ins_srtcontrole_niveau = 'S'"
|
|
+ " AND isc.ins_srtinstallatie_key = d.ins_srtdeel_key"
|
|
+ " OR isc.ins_srtcontrole_niveau = 'G'"
|
|
+ " AND isc.ins_srtinstallatie_key = sd.ins_srtgroep_key"
|
|
+ " OR isc.ins_srtcontrole_niveau = 'D'"
|
|
+ " AND isc.ins_srtinstallatie_key = d.ins_discipline_key)"
|
|
+ " AND isc.ctr_discipline_key = cd.ins_discipline_key"
|
|
+ " AND isc.ins_scenario_key = 1"
|
|
+ " AND d.ins_deel_key = " + ins_key
|
|
+ " AND isc.ins_srtcontrole_key = " + srtcontrole_key;
|
|
var oRs = Oracle.Execute(sql);
|
|
lcl.set_dialect(oRs("ctr_discipline_key").Value, "INS_TAB_DISCIPLINE_KEY");
|
|
|
|
var aantal_std = oRs("ins_deel_aantal").Value;
|
|
var aanteh_std = oRs("ins_srtdeel_eenheid").Value;
|
|
var eenheid_std = oRs("ins_srtcontrole_eenheid").Value;
|
|
var periode_std = oRs("ins_srtcontrole_periode").Value;
|
|
var bits_std = oRs("ins_srtcontrole_bits").Value;
|
|
var kosten1_std = oRs("ins_srtcontrole_kosten").Value;
|
|
var kosten2_std = oRs("ins_srtcontrole_kosten2").Value;
|
|
var kosten3_std = oRs("ins_srtcontrole_kosten3").Value;
|
|
var uren_std = oRs("ins_srtcontrole_uren").Value;
|
|
var materiaal_std = oRs("ins_srtcontrole_materiaal").Value;
|
|
var perc_std = oRs("ins_srtcontrole_percentage").Value;
|
|
var groep_std = oRs("ins_srtcontrole_groep").Value;
|
|
var opmerk_std = oRs("ins_srtcontrole_opmerking").Value;
|
|
var srtcontrole_oms = oRs("ins_srtcontrole_omschrijving").Value;
|
|
var ctrdisc_oms = oRs("ins_discipline_omschrijving").Value;
|
|
|
|
var vervaldatum_std = oRs("ins_srtcontrole_eind").Value? new Date(oRs("ins_srtcontrole_eind").Value) : null;
|
|
var xcp_key_std = oRs("ins_srtcontroledl_xcp_key").Value || -1;
|
|
oRs.Close();
|
|
|
|
// Als de nieuwe waarden gelijk is aan de standaard waarden dan deze niet opslaan.
|
|
var datumdiffer = vervaldatum != null && (vervaldatum? vervaldatum.getTime() : null) != (vervaldatum_std? vervaldatum_std.getTime() : null)
|
|
var paramsdiffer = ((eenheid != -1 && (eenheid != eenheid_std || (periode != null && periode != periode_std) || (bits != null && bits != bits_std))) ||
|
|
(aantal != null && aantal != aantal_std) ||
|
|
(aanteh != "" && aanteh != aanteh_std) ||
|
|
(kosten1 != null && kosten1 != kosten1_std) ||
|
|
(kosten2 != null && kosten2 != kosten2_std) ||
|
|
(kosten3 != null && kosten3 != kosten3_std) ||
|
|
(uren != null && uren != uren_std) ||
|
|
(materiaal != null && materiaal != materiaal_std) ||
|
|
(perc != null && perc != perc_std) ||
|
|
(groep != "" && groep != groep_std) ||
|
|
(opmerk != "" && opmerk != opmerk_std) ||
|
|
datumdiffer || startdatum != null);
|
|
var deactivate = periode_std == 0 && (periode == null || periode == 0); // Beide periodes zijn 0. Controle wordt inactief. Uitzonderings regel kan weg in ins_srtcontroledl_xcp.
|
|
|
|
if (isScenario || (paramsdiffer && !deactivate))
|
|
{ // parameters wijken af van de standaard of er is een startdatum ingevuld.
|
|
var result = { success: true, srtcontroledl_xcp_key: (commit? xcp_key_std : xcp_key) };
|
|
|
|
// De velden opslaan (scenario key blijft hetzelfde dus hoeft niet opgeslagen te worden).
|
|
var fields = [ { dbs: "ins_deel_key", typ: "key", val: ins_key },
|
|
{ dbs: "ins_srtcontrole_key", typ: "key", val: srtcontrole_key },
|
|
{ dbs: "ins_srtcontroledl_xcp_eenheid", typ: "number", val: (eenheid == -1 || eenheid == eenheid_std || eenheid < 0? null : eenheid),
|
|
track: (ins_key > 0? L("lcl_ins_controle_eenheid") + " " + L("lcl_ins_controle").toLowerCase() : null) }, // Waarde gelijk aan standaard niet opslaan.
|
|
{ dbs: "ins_srtcontroledl_xcp_periode", typ: "float", val: (periode == null || periode == periode_std? null : periode),
|
|
track: (ins_key > 0? L("lcl_ins_controle_period") : null) }, // Waarde gelijk aan standaard niet opslaan.
|
|
{ dbs: "ins_srtcontroledl_xcp_bits", typ: "number", val: (bits == null || bits == bits_std? null : bits),
|
|
track: (ins_key > 0? L("ins_srtcontrole_bits") : null) }, // Waarde gelijk aan standaard niet opslaan.
|
|
{ dbs: "ins_srtcontroledl_xcp_uren", typ: "float", val: (uren == null || uren == uren_std? null : uren),
|
|
track: (ins_key > 0? L("ins_srtcontrole_uren") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_perc", typ: "float", val: (perc == null || perc == perc_std? null : perc),
|
|
track: (ins_key > 0? L("ins_srtcontrole_percentage") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_groep", typ: "varchar", val: (groep == "" || groep == groep_std? null : groep),
|
|
track: (ins_key > 0? L("lcl_ins_controle_groep") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_opmerk", typ: "varchar", val: (opmerk == "" || opmerk == opmerk_std? null : opmerk),
|
|
track: (ins_key > 0? L("ins_srtcontrole_opmerking") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_startdat", typ: "datetime", val: startdatum,
|
|
track: (ins_key > 0? L("lcl_ins_startdatum") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_eind", typ: "datetime", val: (datumdiffer? vervaldatum : null),
|
|
track: (ins_key > 0? L("lcl_ins_vervaldatum") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_aantal", typ: "float", val: (aantal == null || aantal == aantal_std? null : aantal),
|
|
track: (ins_key > 0? L("lcl_amount") : null) },
|
|
{ dbs: "ins_srtcontroledl_xcp_aanteh", typ: "varchar", val: (aanteh == "" || aanteh == aanteh_std? null : aanteh),
|
|
track: (ins_key > 0? L("ins_srtcontrole_eenheid") + " " + L("lcl_amount").toLowerCase() : null) }
|
|
];
|
|
|
|
var ins_xcp_active_cost = S("ins_xcp_active_cost");
|
|
if (ins_xcp_active_cost & 1)
|
|
fields.push({ dbs: "ins_srtcontroledl_xcp_kosten", typ: "float", val: (kosten1 == null || kosten1 == kosten1_std? null : kosten1),
|
|
track: (ins_key > 0? L("ins_srtcontrole_kosten") + " (" + (S("currency_pref")).replace(/^\s+|\s+$/gm,'') + ")" : null) });
|
|
if (ins_xcp_active_cost & 2)
|
|
fields.push({ dbs: "ins_srtcontroledl_xcp_kosten2", typ: "float", val: (kosten2 == null || kosten2 == kosten2_std? null : kosten2),
|
|
track: (ins_key > 0? L("ins_srtcontrole_kosten2") + " (" + S("currency_pref").replace(/^\s+|\s+$/gm,'') + ")" : null) });
|
|
if (ins_xcp_active_cost & 4)
|
|
fields.push({ dbs: "ins_srtcontroledl_xcp_kosten3", typ: "float", val: (kosten3 == null || kosten3 == kosten3_std? null : kosten3),
|
|
track: (ins_key > 0? L("ins_srtcontrole_kosten3") + " (" + S("currency_pref").replace(/^\s+|\s+$/gm,'') + ")" : null) });
|
|
if (ins_xcp_active_cost & 8)
|
|
fields.push({ dbs: "ins_srtcontroledl_xcp_materia", typ: "float", val: (materiaal == null || materiaal == materiaal_std? null : materiaal),
|
|
track: (ins_key > 0? L("ins_srtcontrole_materiaal") + " (" + S("currency_pref").replace(/^\s+|\s+$/gm,'') + ")" : null) });
|
|
if (!isScenario && (commit? xcp_key_std : xcp_key) < 0) // Nieuwe inspectie.
|
|
{
|
|
fields.push({ dbs: "ins_srtcontroledl_xcp_key", typ: "key", seq: "ins_s_srtcontroledl_xcp_key" });
|
|
var insIns = buildInsert("ins_srtcontroledl_xcp", fields);
|
|
result.srtcontroledl_xcp_key = insIns.sequences["ins_srtcontroledl_xcp_key"];
|
|
var err = Oracle.Execute(insIns.sql, true);
|
|
|
|
shared.trackaction("#INSUPD", ins_key, L("lcl_ins_controle_obj_upd").format(ctrdisc_oms, srtcontrole_oms)
|
|
+ (!isScenario && scen_key > 0? "\n" + L("lcl_mjb_adjustby_scen").format(params.scen_name) : "")
|
|
+ "\n" + L("lcl_ins_control_add_exception"));
|
|
}
|
|
else
|
|
{
|
|
var insUpd = buildTrackingUpdate("ins_srtcontroledl_xcp", " ins_srtcontroledl_xcp_key = " + (commit? xcp_key_std : xcp_key), fields);
|
|
var err = Oracle.Execute(insUpd.sql, true);
|
|
|
|
if (!isScenario && insUpd && insUpd.trackarray.length)
|
|
shared.trackaction("#INSUPD", ins_key, L("lcl_ins_controle_obj_upd").format(ctrdisc_oms, srtcontrole_oms)
|
|
+ (!isScenario && scen_key > 0? "\n" + L("lcl_mjb_adjustby_scen").format(params.scen_name) : "")
|
|
+ "\n" + insUpd.trackarray.join("\n"));
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// Deactiveren of alle parameter waarden zijn identiek aan de standaard waarden en er is geen groep ingevuld.
|
|
if (xcp_key < 0) // Nieuwe inspectie.
|
|
{ // Geen nieuw record aanmaken.
|
|
var result = { success: true, srtcontroledl_xcp_key: (commit? xcp_key_std : xcp_key), toaster: L("lcl_ins_controle_identical_values") };
|
|
}
|
|
else
|
|
{ // Dan kan het record verwijderd worden.
|
|
var result = { success: true, srtcontroledl_xcp_key: (commit? xcp_key_std : xcp_key), toaster: (deactivate? L("lcl_ins_controle_deactivated") : L("lcl_ins_controle_identical_values")) };
|
|
|
|
// Record verwijderen.
|
|
var sql = "DELETE FROM ins_srtcontroledl_xcp"
|
|
+ " WHERE ins_deel_key = " + ins_key
|
|
+ " AND ins_srtcontrole_key = " + srtcontrole_key
|
|
+ " AND ins_scenario_key = 1";
|
|
var err = Oracle.Execute(sql, true);
|
|
|
|
shared.trackaction("#INSUPD", ins_key, L("lcl_ins_controle_obj_upd").format(ctrdisc_oms, srtcontrole_oms) + "\n" + L("lcl_ins_control_del_exception"));
|
|
}
|
|
}
|
|
|
|
if (err && err.friendlyMsg)
|
|
{
|
|
result.warning = err.friendlyMsg;
|
|
result.success = false;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
}
|
|
%> |