mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-08 23:59:28 +00:00
283 lines
12 KiB
PHP
Executable File
283 lines
12 KiB
PHP
Executable File
<?php
|
|
class Stundenplan_model extends DB_Model
|
|
{
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->dbTable = 'lehre.tbl_stundenplan';
|
|
$this->pk = 'stundenplan_id';
|
|
}
|
|
|
|
/**
|
|
* @param string $ort_kurzbz
|
|
* @param string $date
|
|
*
|
|
* @return stdClass
|
|
*/
|
|
public function getRoomDataOnInterval($ort_kurzbz,$start_date,$end_date){
|
|
|
|
|
|
|
|
/*$raum_stundenplan= $this->execReadOnlyQuery("
|
|
-- merging all reservierungs information with the stundenplan information but with different types
|
|
SELECT 'stundenplan_eintrag' as eintrags_type, CONCAT(UPPER(sp.stg_typ),UPPER(sp.stg_kurzbz),'-',COALESCE(CAST(sp.semester AS varchar),'/'),COALESCE(CAST(sp.verband AS varchar),'/')) AS stg, CONCAT(lehrfach,'-',lehrform) AS lv_info, ort_kurzbz, studiengang_kz, uid, stunde, datum, titel, semester, verband, gruppe, gruppe_kurzbz, stg_kurzbz, * FROM lehre.vw_stundenplan sp
|
|
WHERE ort_kurzbz = ? AND datum >= ? AND datum <= ?
|
|
UNION ALL
|
|
SELECT 'reservierungs_eintrag' as eintrags_type, NULL, NULL, ort_kurzbz, studiengang_kz, uid, stunde, datum, titel, semester, verband, gruppe, gruppe_kurzbz, stg_kurzbz, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL FROM lehre.vw_reservierung res
|
|
WHERE ort_kurzbz = ? AND datum >= ? AND datum <= ?
|
|
", [$ort_kurzbz, $start_date, $end_date,$ort_kurzbz, $start_date, $end_date]);
|
|
*/
|
|
|
|
|
|
$raum_stundenplan= $this->execReadOnlyQuery("
|
|
SELECT CONCAT(UPPER(sp.stg_typ),UPPER(sp.stg_kurzbz),'-',COALESCE(CAST(sp.semester AS varchar),'/'),COALESCE(CAST(sp.verband AS varchar),'/')) AS stg, CONCAT(lehrfach,'-',lehrform) AS lv_info, * FROM lehre.vw_stundenplan sp
|
|
WHERE ort_kurzbz = ? AND datum >= ? AND datum <= ?
|
|
", [$ort_kurzbz, $start_date, $end_date]);
|
|
|
|
return $raum_stundenplan;
|
|
}
|
|
|
|
/**
|
|
* @param string $ort_kurzbz The room to query the planning for
|
|
* @param string $start_date The start date of the query interval
|
|
* @param string $end_date The end date of the query interval
|
|
*
|
|
* @return stdClass
|
|
*/
|
|
public function groupedCalendarEvents($ort_kurzbz,$start_date,$end_date){
|
|
|
|
|
|
$gruppierteEvents= $this->execReadOnlyQuery("
|
|
SELECT
|
|
|
|
'reservierung' as type,
|
|
NULL as unr,datum, stunde,
|
|
titel AS topic,
|
|
beschreibung as beschreibung,
|
|
string_agg(DISTINCT gruppe, '/') as gruppe,
|
|
string_agg(DISTINCT lektor, '/') as lektor,
|
|
res.ort_kurzbz,res.studiengang_kz, res.titel, res.beschreibung,NULL as lehreinheit_id,NULL as lehrfach_id,NULL as anmerkung, NULL as fix,NULL as lehrveranstaltung_id,NULL as stg_kurzbzlang,NULL as stg_bezeichnung,NULL as stg_typ, NULL as fachbereich_kurzbz,NULL as lehrfach,NULL as lehrfach_bez,NULL as farbe,NULL as lehrform, NULL as anmerkung_lehreinheit
|
|
|
|
FROM
|
|
|
|
(
|
|
SELECT
|
|
NULL as unr,datum, stunde,
|
|
CASE
|
|
WHEN gruppe_kurzbz IS NOT NULL THEN gruppe_kurzbz
|
|
ELSE CONCAT(UPPER(studg.typ),UPPER(res.stg_kurzbz),'-',COALESCE(CAST(res.semester AS varchar),'/'),COALESCE(CAST(res.verband AS varchar),'/'))
|
|
END as gruppe,
|
|
CASE
|
|
WHEN mit.kurzbz IS NOT NULL THEN mit.kurzbz
|
|
ELSE uid
|
|
END as lektor,
|
|
res.ort_kurzbz,res.studiengang_kz, res.titel, res.beschreibung,NULL as lehreinheit_id,NULL as lehrfach_id,NULL as anmerkung, NULL as fix,NULL as lehrveranstaltung_id,NULL as stg_kurzbzlang,NULL as stg_bezeichnung,NULL as stg_typ, NULL as fachbereich_kurzbz,NULL as lehrfach,NULL as lehrfach_bez,NULL as farbe,NULL as lehrform, NULL as anmerkung_lehreinheit
|
|
FROM lehre.vw_reservierung res
|
|
|
|
LEFT JOIN public.tbl_mitarbeiter mit ON mit.mitarbeiter_uid=uid
|
|
JOIN public.tbl_studiengang studg ON studg.studiengang_kz=res.studiengang_kz
|
|
|
|
WHERE
|
|
res.ort_kurzbz = ?
|
|
AND res.datum >= ?
|
|
AND res.datum <= ?
|
|
) as res
|
|
|
|
GROUP BY res.ort_kurzbz,res.studiengang_kz, res.datum, res.stunde, res.titel, res.beschreibung
|
|
|
|
UNION ALL
|
|
|
|
SELECT
|
|
|
|
'stundenplan' as type,
|
|
unr,datum, stunde,
|
|
CONCAT(lehrfach,'-',lehrform) as topic,
|
|
'' as beschreibung,
|
|
string_agg(DISTINCT gruppe, '/') as gruppe,
|
|
string_agg(DISTINCT lektor, '/') as lektor,
|
|
ort_kurzbz, studiengang_kz, titel,'' as beschreibung,lehreinheit_id,lehrfach_id,anmerkung,fix,lehrveranstaltung_id,stg_kurzbzlang,stg_bezeichnung,stg_typ,fachbereich_kurzbz,lehrfach,lehrfach_bez,farbe,lehrform,anmerkung_lehreinheit
|
|
|
|
FROM
|
|
(
|
|
SELECT
|
|
unr,datum, stunde,
|
|
CASE
|
|
WHEN gruppe_kurzbz IS NOT NULL THEN gruppe_kurzbz
|
|
ELSE CONCAT(UPPER(sp.stg_typ),UPPER(sp.stg_kurzbz),'-',COALESCE(CAST(sp.semester AS varchar),'/'),COALESCE(CAST(sp.verband AS varchar),'/'))
|
|
END as gruppe,
|
|
CASE
|
|
WHEN sp.mitarbeiter_kurzbz IS NOT NULL THEN sp.mitarbeiter_kurzbz
|
|
ELSE lektor
|
|
END as lektor,
|
|
ort_kurzbz, studiengang_kz, titel,'' as beschreibung,lehreinheit_id,lehrfach_id,anmerkung,fix,lehrveranstaltung_id,stg_kurzbzlang,stg_bezeichnung,stg_typ,fachbereich_kurzbz,lehrfach,lehrfach_bez,farbe,lehrform,anmerkung_lehreinheit
|
|
|
|
FROM lehre.vw_stundenplan sp
|
|
|
|
WHERE ort_kurzbz = ?
|
|
AND datum >= ?
|
|
AND datum <= ?
|
|
|
|
) as sp
|
|
|
|
GROUP BY
|
|
|
|
ort_kurzbz,unr, datum, stunde, lehreinheit_id, lehrfach_id,studiengang_kz,titel,anmerkung,fix,lehrveranstaltung_id,stg_kurzbzlang,stg_bezeichnung,stg_typ,fachbereich_kurzbz,lehrfach,lehrfach_bez,farbe,lehrform,anmerkung_lehreinheit
|
|
|
|
ORDER BY datum, stunde
|
|
", [$ort_kurzbz, $start_date, $end_date, $ort_kurzbz, $start_date, $end_date]);
|
|
|
|
return $gruppierteEvents;
|
|
}
|
|
|
|
|
|
/**
|
|
* function that takes a query that fetches lehre.vw_stundenplan rows and groups them so that they can be displayed in a calendar
|
|
* @param string $stundenplanViewQuery the subquery used to group the result
|
|
*
|
|
* @return stdClass
|
|
*/
|
|
public function stundenplanGruppierung($stundenplanViewQuery)
|
|
{
|
|
$query_result = $this->execReadOnlyQuery("
|
|
SELECT
|
|
'lehreinheit' as type, beginn, ende, datum,
|
|
CONCAT(lehrfach,'-',lehrform) as topic,
|
|
array_agg(DISTINCT lektor) as lektor,
|
|
array_agg(DISTINCT (gruppe,verband,semester,studiengang_kz,gruppen_kuerzel)) as gruppe,
|
|
string_agg(DISTINCT ort_kurzbz, '/') as ort_kurzbz,
|
|
array_agg(DISTINCT lehreinheit_id) as lehreinheit_id,
|
|
|
|
titel, lehrfach, lehrform, lehrfach_bez, organisationseinheit, farbe, lehrveranstaltung_id
|
|
|
|
FROM
|
|
(
|
|
SELECT unr,datum,beginn, ende,
|
|
CASE
|
|
WHEN sp.mitarbeiter_kurzbz IS NOT NULL THEN sp.mitarbeiter_kurzbz
|
|
ELSE lektor
|
|
END as lektor,
|
|
CASE
|
|
WHEN gruppe_kurzbz IS NOT NULL THEN gruppe_kurzbz
|
|
ELSE CONCAT(UPPER(sp.stg_typ),UPPER(sp.stg_kurzbz),'-',COALESCE(CAST(sp.semester AS varchar),'/'),COALESCE(CAST(sp.verband AS varchar),'/'))
|
|
END as gruppen_kuerzel,
|
|
(SELECT bezeichnung
|
|
FROM public.tbl_organisationseinheit
|
|
WHERE oe_kurzbz IN(
|
|
SELECT oe_kurzbz
|
|
FROM lehre.tbl_lehrveranstaltung
|
|
WHERE lehrveranstaltung_id = sp.lehrveranstaltung_id
|
|
)) as organisationseinheit,
|
|
ort_kurzbz, studiengang_kz, titel,lehreinheit_id,lehrfach_id,anmerkung,fix,lehrveranstaltung_id,stg_kurzbzlang,stg_bezeichnung,stg_typ,fachbereich_kurzbz,lehrfach,lehrfach_bez,farbe,lehrform,anmerkung_lehreinheit,gruppe, verband, semester,stg_kurzbz
|
|
|
|
FROM (".$stundenplanViewQuery.") sp
|
|
JOIN lehre.tbl_stunde ON lehre.tbl_stunde.stunde = sp.stunde
|
|
|
|
) as subquery
|
|
|
|
GROUP BY unr, datum, beginn, ende, ort_kurzbz, titel, lehrform, lehrfach, lehrfach_bez, organisationseinheit, farbe, lehrveranstaltung_id
|
|
|
|
ORDER BY datum, beginn
|
|
");
|
|
|
|
return $query_result;
|
|
}
|
|
|
|
/**
|
|
* NO STANDALONE FUNCTION - Generates a SQL query string to fetch 'stundenplan' events for a specific student within the current semester.
|
|
* @param string $uid the user id that is used to fetch the stundenplan rows from the lehre.vw_stundenplan table
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getStundenplanQuery($uid, $start_date, $end_date,$studiengang_kz,$semester){
|
|
|
|
$studiensemester = null;
|
|
|
|
$check_with_start_date = $this->execReadOnlyQuery("SELECT * FROM public.tbl_studiensemester WHERE " . $this->escape($start_date) . " BETWEEN start AND ende ;");
|
|
$check_with_start_date = getData($check_with_start_date);
|
|
if (count($check_with_start_date)>0)
|
|
{
|
|
$studiensemester = current($check_with_start_date)->studiensemester_kurzbz;
|
|
}
|
|
else
|
|
{
|
|
$check_with_end_date = $this->execReadOnlyQuery("SELECT * FROM public.tbl_studiensemester WHERE " . $this->escape($end_date) . " BETWEEN start AND ende ;");
|
|
$check_with_end_date = getData($check_with_end_date);
|
|
if (count($check_with_start_date) > 0)
|
|
{
|
|
$studiensemester = current($check_with_end_date)->studiensemester_kurzbz;
|
|
}
|
|
}
|
|
|
|
if(!is_null($studiensemester))
|
|
{
|
|
$semester_with_studiensemester = $this->execReadOnlyQuery("SELECT * FROM public.tbl_studentlehrverband WHERE student_uid = " . $this->escape($uid) . " AND studiensemester_kurzbz = " . $this->escape($studiensemester));
|
|
$semester_with_studiensemester = getData($semester_with_studiensemester);
|
|
$semester_with_studiensemester = current($semester_with_studiensemester)->semester;
|
|
|
|
return
|
|
"select sp.*
|
|
from lehre.vw_stundenplan sp
|
|
left join public.tbl_benutzergruppe bg ON sp.gruppe_kurzbz=bg.gruppe_kurzbz AND bg.uid =".$this->escape($uid)."
|
|
left join public.tbl_studiensemester ss1 ON bg.studiensemester_kurzbz=ss1.studiensemester_kurzbz AND ss1.start <=sp.datum AND ss1.ende>= sp.datum
|
|
left join public.tbl_studentlehrverband slv ON sp.studiengang_kz=slv.studiengang_kz and slv.student_uid=".$this->escape($uid)." and (slv.semester=sp.semester OR sp.semester IS NULL) AND (slv.verband=sp.verband OR sp.verband IS NULL OR sp.verband='' OR sp.verband='0') AND
|
|
(slv.gruppe=sp.gruppe OR sp.gruppe IS NULL OR sp.gruppe='' OR sp.gruppe='0') AND sp.gruppe_kurzbz IS NULL
|
|
left join public.tbl_studiensemester ss2 ON slv.studiensemester_kurzbz=ss2.studiensemester_kurzbz AND ss2.start<=sp.datum and ss2.ende >= sp.datum
|
|
WHERE
|
|
sp.datum >= ".$this->escape($start_date)."
|
|
AND sp.datum <= ".$this->escape($end_date)."
|
|
AND sp.studiengang_kz = ".$this->escape($studiengang_kz)."
|
|
AND sp.semester = ".$this->escape($semester_with_studiensemester)."
|
|
AND (ss1.studiensemester_kurzbz IS NOT NULL or ss2.studiensemester_kurzbz IS NOT NULL)";
|
|
|
|
}
|
|
else
|
|
{
|
|
return error("studiensemester could not be retrieved with the student_uid: ".$uid);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* NO STANDALONE FUNCTION - Generates a SQL query string to fetch 'stundenplan' events for a specific room within a date range.
|
|
* @param string $ort_kurzbz the ort from which we want to query the stundenplan events
|
|
* @param string $start_date (inclusive) the minimum date that an event should have to be fetched
|
|
* @param string $end_date (inclusive) the maximum date that an event should not extend to be fetched
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getRoomQuery($ort_kurzbz, $start_date, $end_date)
|
|
{
|
|
return
|
|
"select sp.*
|
|
FROM lehre.vw_stundenplan sp
|
|
WHERE ort_kurzbz = ".$this->escape($ort_kurzbz)."
|
|
AND datum >= ".$this->escape($start_date)."
|
|
AND datum <= ".$this->escape($end_date);
|
|
}
|
|
|
|
/**
|
|
* @param string $uid
|
|
*
|
|
* @return stdClass
|
|
*/
|
|
public function loadForUid($uid)
|
|
{
|
|
$this->addSelect(['sp.*','le.studiensemester_kurzbz']);
|
|
$this->db->join('public.tbl_benutzergruppe bg', 'sp.gruppe_kurzbz=bg.gruppe_kurzbz AND bg.uid=?', 'LEFT', false);
|
|
$this->addJoin('public.tbl_studiensemester ss1', 'bg.studiensemester_kurzbz=ss1.studiensemester_kurzbz AND ss1.start<=sp.datum AND ss1.ende>=sp.datum', 'LEFT');
|
|
$this->db->join('public.tbl_studentlehrverband slv', "sp.studiengang_kz=slv.studiengang_kz AND slv.student_uid=? AND (slv.semester=sp.semester OR sp.semester IS NULL) AND (slv.verband=sp.verband OR sp.verband IS NULL OR sp.verband='' OR sp.verband='0') AND (slv.gruppe=sp.gruppe OR sp.gruppe IS NULL OR sp.gruppe='' OR sp.gruppe='0') AND sp.gruppe_kurzbz IS NULL", 'LEFT', false);
|
|
$this->addJoin('public.tbl_studiensemester ss2', 'slv.studiensemester_kurzbz=ss2.studiensemester_kurzbz AND ss2.start<=sp.datum AND ss2.ende>=sp.datum', 'LEFT');
|
|
$this->db->join('lehre.tbl_lehreinheit le', 'le.lehreinheit_id=sp.lehreinheit_id', 'LEFT');
|
|
$this->db->or_where('ss1.studiensemester_kurzbz IS NOT NULL', null, false);
|
|
$this->db->or_where('ss2.studiensemester_kurzbz IS NOT NULL', null, false);
|
|
|
|
$query = $this->db->get_compiled_select('lehre.vw_stundenplan sp');
|
|
|
|
return $this->execQuery($query, [$uid, $uid]);
|
|
}
|
|
|
|
}
|