Adapted tabulator data-query (row index; some extra columns)

. Added incrementing id column which provides unique number to enable
tabulator to use it as row index.

. Added extra colums studiengang_kz, lv_oe_kurzbz
This commit is contained in:
Cris
2019-09-12 14:16:08 +02:00
committed by hainberg
parent 35b37179e9
commit b92f3a1ee5
@@ -4,120 +4,138 @@ $STUDIENSEMESTER = $studiensemester_selected;
$STUDIENGANG = (isset($studiengang_selected) && !is_null($studiengang_selected)) ? array($studiengang_selected) : $studiengang;
$query = '
/* Lehraufträge and -vertragsstati */
SELECT
lema.lehreinheit_id AS "LE_ID",
upper(lv.lehrtyp_kurzbz) AS "Typ",
(lv.bezeichnung || \' [\' || le.lehrform_kurzbz || \' \' || lv.semester || \'.Semester\' || \']\') AS "Auftrag",
CASE
WHEN oe.organisationseinheittyp_kurzbz = \'Kompetenzfeld\' THEN (\'KF \' || oe.bezeichnung)
WHEN oe.organisationseinheittyp_kurzbz = \'Department\' THEN (\'DEP \' || oe.bezeichnung)
ELSE (oe.organisationseinheittyp_kurzbz || \' \' || oe.bezeichnung)
END AS "Organisationseinheit",
CONCAT(stg.kurzbzlang, \'-\', legr.semester, legr.verband, legr.gruppe, \'\n\' || legr.gruppe_kurzbz) AS "Gruppe",
(person.vorname || \' \' || person.nachname) AS "Lektor",
TRUNC(lema.semesterstunden, 1) AS "Stunden",
TRUNC((lema.semesterstunden * lema.stundensatz), 2) AS "Betrag",
CASE
/* existing contracts for given study semester with status bestellt */
WHEN lema.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'bestellt\' THEN vvs.datum
END AS "Bestellt",
CASE
/* existing contracts for given study semester with status erteilt */
WHEN lema.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'erteilt\' THEN vvs.datum
END AS "Erteilt",
CASE
/* existing contracts for given study semester with status akzeptiert */
WHEN lema.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'akzeptiert\' THEN vvs.datum
END AS "Akzeptiert"
FROM
lehre.tbl_lehreinheitmitarbeiter lema
JOIN lehre.tbl_lehreinheit le USING (lehreinheit_id)
JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
JOIN public.tbl_organisationseinheit oe USING (oe_kurzbz)
JOIN lehre.tbl_lehreinheitgruppe legr USING (lehreinheit_id)
JOIN public.tbl_mitarbeiter ma USING (mitarbeiter_uid)
JOIN public.tbl_benutzer benutzer ON ma.mitarbeiter_uid = benutzer.uid
JOIN public.tbl_person person USING (person_id)
LEFT JOIN lehre.tbl_vertrag vertrag USING (vertrag_id)
LEFT JOIN lehre.tbl_vertrag_vertragsstatus vvs USING (vertrag_id)
LEFT JOIN lehre.tbl_vertragsstatus status USING (vertragsstatus_kurzbz)
JOIN public.tbl_studiengang stg ON stg.studiengang_kz = lv.studiengang_kz
WHERE
/* filter studiengang */
lv.studiengang_kz IN ('. implode(',', $STUDIENGANG) . ')
/* filter studiensemester */
AND le.studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\'
/* filter active lehrveranstaltungen */
AND lv.aktiv = TRUE
/* filter dummies and invalid mitarbeiter */
AND ma.personalnummer >= 0
UNION
/* Projektbetreuungsaufträge and -vertragsstati */
SELECT
pa.lehreinheit_id AS "LE_ID",
\'Betreuung\' AS "Typ",
(betreuerart_kurzbz || \' \' ||
(SELECT
vorname || \' \' || nachname
FROM
public.tbl_person
JOIN public.tbl_benutzer USING (person_id)
WHERE
uid = pa.student_uid)
|| \' [\' || projekttyp_kurzbz || \'arbeit\' || \' \' || lv.semester || \'.Semester]\') AS "Auftrag",
CASE
WHEN oe.organisationseinheittyp_kurzbz = \'Kompetenzfeld\' THEN (\'KF \' || oe.bezeichnung)
WHEN oe.organisationseinheittyp_kurzbz = \'Department\' THEN (\'DEP \' || oe.bezeichnung)
ELSE (oe.organisationseinheittyp_kurzbz || \' \' || oe.bezeichnung)
END AS "Organisationseinheit",
CONCAT(stg.kurzbzlang, \'-\', legr.semester, legr.verband, legr.gruppe, \'\n\' || legr.gruppe_kurzbz) AS "Gruppe",
(vorname || \' \' || nachname) AS "Lektor",
TRUNC(pb.stunden, 1) AS "Stunden",
TRUNC((pb.stunden * pb.stundensatz), 2) AS "Betrag",
CASE
/* existing contracts for given study semester with status bestellt */
WHEN pb.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'bestellt\' THEN vvs.datum
END AS "Bestellt",
CASE
/* existing contracts for given study semester with status erteilt */
WHEN pb.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'erteilt\' THEN vvs.datum
END AS "Erteilt",
CASE
/* existing contracts for given study semester with status akzeptiert */
WHEN pb.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'akzeptiert\' THEN vvs.datum
END AS "Akzeptiert"
FROM
lehre.tbl_projektbetreuer pb
JOIN lehre.tbl_projektarbeit pa USING (projektarbeit_id)
JOIN lehre.tbl_lehreinheit le USING (lehreinheit_id)
JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
JOIN public.tbl_organisationseinheit oe USING (oe_kurzbz)
JOIN lehre.tbl_lehreinheitgruppe legr USING (lehreinheit_id)
JOIN public.tbl_person person USING (person_id)
LEFT JOIN lehre.tbl_vertrag vertrag USING (vertrag_id)
LEFT JOIN lehre.tbl_vertrag_vertragsstatus vvs USING (vertrag_id)
LEFT JOIN lehre.tbl_vertragsstatus status USING (vertragsstatus_kurzbz)
JOIN public.tbl_studiengang stg ON stg.studiengang_kz = lv.studiengang_kz
WHERE
/* filter studiengang */
lv.studiengang_kz IN ('. implode(',', $STUDIENGANG) . ')
/* filter studiensemester */
AND le.studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\'
/* filter active lehrveranstaltungen */
AND lv.aktiv = TRUE
ORDER BY "Typ" DESC, "Auftrag", "Lektor"
';
SELECT
ROW_NUMBER() OVER () AS "id",
*
FROM
(
/* Lehraufträge and -vertragsstati */
SELECT
lema.lehreinheit_id AS "LE_ID",
lv.lehrveranstaltung_id AS "LV_ID",
NULL AS "PA_ID",
le.studiensemester_kurzbz AS "Studiensemester",
stg.studiengang_kz,
person.person_id AS "Person_ID",
upper(lv.lehrtyp_kurzbz) AS "Typ",
(lv.bezeichnung || \' [\' || le.lehrform_kurzbz || \' \' || lv.semester || \'.Semester\' || \']\') AS "Auftrag",
CASE
WHEN oe.organisationseinheittyp_kurzbz = \'Kompetenzfeld\' THEN (\'KF \' || oe.bezeichnung)
WHEN oe.organisationseinheittyp_kurzbz = \'Department\' THEN (\'DEP \' || oe.bezeichnung)
ELSE (oe.organisationseinheittyp_kurzbz || \' \' || oe.bezeichnung)
END AS "Organisationseinheit",
lv.oe_kurzbz AS "lv_oe_kurzbz",
CONCAT(stg.kurzbzlang, \'-\', legr.semester, legr.verband, legr.gruppe, \'\n\' || legr.gruppe_kurzbz) AS "Gruppe",
(person.vorname || \' \' || person.nachname) AS "Lektor",
TRUNC(lema.semesterstunden, 1) AS "Stunden",
TRUNC((lema.semesterstunden * lema.stundensatz), 2) AS "Betrag",
CASE
/* existing contracts for given study semester with status bestellt */
WHEN lema.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'bestellt\' THEN vvs.datum
END AS "Bestellt",
CASE
/* existing contracts for given study semester with status erteilt */
WHEN lema.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'erteilt\' THEN vvs.datum
END AS "Erteilt",
CASE
/* existing contracts for given study semester with status akzeptiert */
WHEN lema.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'akzeptiert\' THEN vvs.datum
END AS "Akzeptiert"
FROM
lehre.tbl_lehreinheitmitarbeiter lema
JOIN lehre.tbl_lehreinheit le USING (lehreinheit_id)
JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
JOIN public.tbl_organisationseinheit oe USING (oe_kurzbz)
JOIN lehre.tbl_lehreinheitgruppe legr USING (lehreinheit_id)
JOIN public.tbl_mitarbeiter ma USING (mitarbeiter_uid)
JOIN public.tbl_benutzer benutzer ON ma.mitarbeiter_uid = benutzer.uid
JOIN public.tbl_person person USING (person_id)
LEFT JOIN lehre.tbl_vertrag vertrag USING (vertrag_id)
LEFT JOIN lehre.tbl_vertrag_vertragsstatus vvs USING (vertrag_id)
LEFT JOIN lehre.tbl_vertragsstatus status USING (vertragsstatus_kurzbz)
JOIN public.tbl_studiengang stg ON stg.studiengang_kz = lv.studiengang_kz
WHERE
/* filter studiengang */
lv.studiengang_kz IN ('. implode(',', $STUDIENGANG) . ')
/* filter studiensemester */
AND le.studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\'
/* filter active lehrveranstaltungen */
AND lv.aktiv = TRUE
/* filter dummies and invalid mitarbeiter */
AND ma.personalnummer >= 0
UNION
/* Projektbetreuungsaufträge and -vertragsstati */
SELECT
pa.lehreinheit_id AS "LE_ID",
lv.lehrveranstaltung_id AS "LV_ID",
pa.projektarbeit_id AS "PA_ID",
le.studiensemester_kurzbz AS "Studiensemester",
stg.studiengang_kz,
person.person_id AS "Person_ID",
\'Betreuung\' AS "Typ",
(betreuerart_kurzbz || \' \' ||
(SELECT
vorname || \' \' || nachname
FROM
public.tbl_person
JOIN public.tbl_benutzer USING (person_id)
WHERE
uid = pa.student_uid)
|| \' [\' || projekttyp_kurzbz || \'arbeit\' || \' \' || lv.semester || \'.Semester]\') AS "Auftrag",
CASE
WHEN oe.organisationseinheittyp_kurzbz = \'Kompetenzfeld\' THEN (\'KF \' || oe.bezeichnung)
WHEN oe.organisationseinheittyp_kurzbz = \'Department\' THEN (\'DEP \' || oe.bezeichnung)
ELSE (oe.organisationseinheittyp_kurzbz || \' \' || oe.bezeichnung)
END AS "Organisationseinheit",
lv.oe_kurzbz AS "lv_oe_kurzbz",
CONCAT(stg.kurzbzlang, \'-\', legr.semester, legr.verband, legr.gruppe, \'\n\' || legr.gruppe_kurzbz) AS "Gruppe",
(vorname || \' \' || nachname) AS "Lektor",
TRUNC(pb.stunden, 1) AS "Stunden",
TRUNC((pb.stunden * pb.stundensatz), 2) AS "Betrag",
CASE
/* existing contracts for given study semester with status bestellt */
WHEN pb.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'bestellt\' THEN vvs.datum
END AS "Bestellt",
CASE
/* existing contracts for given study semester with status erteilt */
WHEN pb.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'erteilt\' THEN vvs.datum
END AS "Erteilt",
CASE
/* existing contracts for given study semester with status akzeptiert */
WHEN pb.vertrag_id NOTNULL AND vertrag.vertragsstunden_studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\' AND
vvs.vertragsstatus_kurzbz = \'akzeptiert\' THEN vvs.datum
END AS "Akzeptiert"
FROM
lehre.tbl_projektbetreuer pb
JOIN lehre.tbl_projektarbeit pa USING (projektarbeit_id)
JOIN lehre.tbl_lehreinheit le USING (lehreinheit_id)
JOIN lehre.tbl_lehrveranstaltung lv USING (lehrveranstaltung_id)
JOIN public.tbl_organisationseinheit oe USING (oe_kurzbz)
JOIN lehre.tbl_lehreinheitgruppe legr USING (lehreinheit_id)
JOIN public.tbl_person person USING (person_id)
LEFT JOIN lehre.tbl_vertrag vertrag USING (vertrag_id)
LEFT JOIN lehre.tbl_vertrag_vertragsstatus vvs USING (vertrag_id)
LEFT JOIN lehre.tbl_vertragsstatus status USING (vertragsstatus_kurzbz)
JOIN public.tbl_studiengang stg ON stg.studiengang_kz = lv.studiengang_kz
WHERE
/* filter studiengang */
lv.studiengang_kz IN ('. implode(',', $STUDIENGANG) . ')
/* filter studiensemester */
AND le.studiensemester_kurzbz = \''. $STUDIENSEMESTER. '\'
/* filter active lehrveranstaltungen */
AND lv.aktiv = TRUE
ORDER BY "Typ" DESC, "Auftrag", "Lektor"
) auftraege
';
$filterWidgetArray = array(
@@ -179,20 +197,3 @@ echo $this->widgetlib->widget('FilterWidget', $filterWidgetArray);
?>
<script type="text/javascript">
$(function() {
// NOTE: $("#filterTabulator").tabulator gives access to Tabulator object
var selector = $("#filterTabulator");
// Select all (filtered) rows
$("#select-all").click(function(){
selector.tabulator("selectRow", true); // true selects all filtered rows
});
// Deselect all (filtered) rows
$("#deselect-all").click(function(){
selector.tabulator("deselectRow");
});
});
</script>