mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-07 07:09:27 +00:00
342 lines
13 KiB
PHP
342 lines
13 KiB
PHP
<?php
|
|
/* Copyright (C) 2008 Technikum-Wien
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
* Authors: Christian Paminger <christian.paminger@technikum-wien.at>,
|
|
* Andreas Oesterreicher <andreas.oesterreicher@technikum-wien.at>,
|
|
* Rudolf Hangl <rudolf.hangl@technikum-wien.at> and
|
|
*/
|
|
// Erstellt ein Excel mit den Kosten der Lehrveranstaltungen
|
|
require_once('../../vilesci/config.inc.php');
|
|
require_once('../../include/functions.inc.php');
|
|
require_once('../../include/studiengang.class.php');
|
|
require_once('../../include/Excel/excel.php');
|
|
require_once('../../include/person.class.php');
|
|
require_once('../../include/benutzer.class.php');
|
|
require_once('../../include/mitarbeiter.class.php');
|
|
|
|
if(!$conn=pg_pconnect(CONN_STRING))
|
|
die('Fehler biem Connecten zur DB');
|
|
|
|
$user = get_uid();
|
|
loadVariables($conn, $user);
|
|
|
|
if(isset($_GET['studiensemester_kurzbz']))
|
|
$studiensemester_kurzbz = $_GET['studiensemester_kurzbz'];
|
|
else
|
|
die('studiensemester_kurzbz muss uebergeben werden');
|
|
|
|
if(isset($_GET['studiengang_kz']))
|
|
$studiengang_kz = $_GET['studiengang_kz'];
|
|
else
|
|
$studiengang_kz='';
|
|
|
|
if(isset($_GET['semester']))
|
|
$semester = $_GET['semester'];
|
|
else
|
|
$semester='';
|
|
|
|
if(isset($_GET['institut']))
|
|
$institut = $_GET['institut'];
|
|
else
|
|
$institut = '';
|
|
|
|
if(isset($_GET['uid']))
|
|
$uid = $_GET['uid'];
|
|
else
|
|
$uid = '';
|
|
|
|
$stg_obj = new studiengang($conn);
|
|
$stg_obj->getAll('typ, kurzbz', false);
|
|
|
|
// Creating a workbook
|
|
$workbook = new Spreadsheet_Excel_Writer();
|
|
|
|
// sending HTTP headers
|
|
$workbook->send("LVPlanung.xls");
|
|
|
|
// Creating a worksheet
|
|
$worksheet =& $workbook->addWorksheet($studiensemester_kurzbz);
|
|
|
|
//Formate Definieren
|
|
$format_bold =& $workbook->addFormat();
|
|
$format_bold->setBold();
|
|
|
|
$format_number =& $workbook->addFormat();
|
|
$format_number->setNumFormat('0,0.00');
|
|
|
|
$format_number_bold =& $workbook->addFormat();
|
|
$format_number_bold->setNumFormat('0,0.00');
|
|
$format_number_bold->setBold();
|
|
|
|
|
|
$qry = "
|
|
SELECT (SELECT nachname FROM public.tbl_person JOIN public.tbl_benutzer USING(person_id)
|
|
WHERE uid=COALESCE(koordinator, (SELECT uid FROM public.tbl_benutzerfunktion
|
|
WHERE fachbereich_kurzbz=tbl_lehrfach.fachbereich_kurzbz AND
|
|
studiengang_kz=tbl_lehrveranstaltung.studiengang_kz AND
|
|
funktion_kurzbz='fbk' LIMIT 1
|
|
)
|
|
)
|
|
) as koordinator,
|
|
tbl_lehrfach.bezeichnung as lf_bezeichnung, tbl_lehrveranstaltung.studiengang_kz,
|
|
tbl_lehrfach.fachbereich_kurzbz as fachbereich_kurzbz, tbl_lehreinheitmitarbeiter.mitarbeiter_uid,
|
|
tbl_lehrveranstaltung.semester as lv_semester, tbl_lehreinheit.lehreinheit_id, tbl_lehreinheitmitarbeiter.faktor,
|
|
tbl_lehreinheitmitarbeiter.stundensatz,
|
|
tbl_lehreinheitmitarbeiter.semesterstunden, tbl_lehreinheitmitarbeiter.planstunden,
|
|
tbl_lehreinheit.stundenblockung, tbl_lehreinheit.wochenrythmus, tbl_lehreinheit.raumtyp, tbl_lehreinheit.raumtypalternativ,
|
|
tbl_lehreinheitmitarbeiter.anmerkung
|
|
FROM
|
|
lehre.tbl_lehrveranstaltung JOIN lehre.tbl_lehreinheit USING(lehrveranstaltung_id)
|
|
JOIN lehre.tbl_lehreinheitmitarbeiter USING(lehreinheit_id)
|
|
JOIN lehre.tbl_lehrfach USING(lehrfach_id)
|
|
WHERE
|
|
tbl_lehreinheit.studiensemester_kurzbz='".addslashes($studiensemester_kurzbz)."'";
|
|
|
|
if($studiengang_kz!='')
|
|
$qry.=" AND tbl_lehrveranstaltung.studiengang_kz='".addslashes($studiengang_kz)."'";
|
|
|
|
if($institut!='')
|
|
$qry.=" AND tbl_lehrfach.fachbereich_kurzbz='".addslashes($institut)."'";
|
|
|
|
if($semester!='')
|
|
$qry.=" AND tbl_lehrveranstaltung.semesteR='".addslashes($semester)."'";
|
|
|
|
if($uid!='')
|
|
$qry.=" AND tbl_lehreinheitmitarbeiter.mitarbeiter_uid='".addslashes($uid)."'";
|
|
|
|
$qry.=" ORDER BY tbl_lehrveranstaltung.studiengang_kz, tbl_lehrveranstaltung.semester, tbl_lehrveranstaltung.bezeichnung";
|
|
$zeile=0;
|
|
$spalte=0;
|
|
$worksheet->write($zeile,$spalte,"Studiengang", $format_bold);
|
|
$maxlength[$spalte]=11;
|
|
$worksheet->write($zeile,++$spalte,"Institut", $format_bold);
|
|
$maxlength[$spalte]=8;
|
|
$worksheet->write($zeile,++$spalte,"Koordinator", $format_bold);
|
|
$maxlength[$spalte]=11;
|
|
$worksheet->write($zeile,++$spalte,"Lektor", $format_bold);
|
|
$maxlength[$spalte]=6;
|
|
$worksheet->write($zeile,++$spalte,"Lehrfach", $format_bold);
|
|
$maxlength[$spalte]=8;
|
|
$worksheet->write($zeile,++$spalte,"Semester", $format_bold);
|
|
$maxlength[$spalte]=8;
|
|
$worksheet->write($zeile,++$spalte,"Gruppen", $format_bold);
|
|
$maxlength[$spalte]=7;
|
|
$worksheet->write($zeile,++$spalte,"Stunden", $format_bold);
|
|
$maxlength[$spalte]=7;
|
|
$worksheet->write($zeile,++$spalte,"Kosten", $format_bold);
|
|
$maxlength[$spalte]=6;
|
|
$worksheet->write($zeile,++$spalte,"Planstunden", $format_bold);
|
|
$maxlength[$spalte]=11;
|
|
$worksheet->write($zeile,++$spalte,"Stundenblockung", $format_bold);
|
|
$maxlength[$spalte]=15;
|
|
$worksheet->write($zeile,++$spalte,"Wochenrythmus", $format_bold);
|
|
$maxlength[$spalte]=13;
|
|
$worksheet->write($zeile,++$spalte,"Raum", $format_bold);
|
|
$maxlength[$spalte]=4;
|
|
$worksheet->write($zeile,++$spalte,"Raum alternativ", $format_bold);
|
|
$maxlength[$spalte]=15;
|
|
$worksheet->write($zeile,++$spalte,"Anmerkung", $format_bold);
|
|
$maxlength[$spalte]=9;
|
|
|
|
if($result = pg_query($conn, $qry))
|
|
{
|
|
while($row = pg_fetch_object($result))
|
|
{
|
|
$spalte=0;
|
|
$zeile++;
|
|
|
|
$mitarbeiter = new mitarbeiter($conn);
|
|
$mitarbeiter->load($row->mitarbeiter_uid);
|
|
|
|
//Studiengang
|
|
$worksheet->write($zeile,$spalte,$stg_obj->kuerzel_arr[$row->studiengang_kz]);
|
|
if($maxlength[$spalte]<strlen($stg_obj->kuerzel_arr[$row->studiengang_kz]))
|
|
$maxlength[$spalte]=strlen($stg_obj->kuerzel_arr[$row->studiengang_kz]);
|
|
//Fachbereich
|
|
$worksheet->write($zeile,++$spalte,$row->fachbereich_kurzbz);
|
|
if($maxlength[$spalte]<strlen($row->fachbereich_kurzbz))
|
|
$maxlength[$spalte]=strlen($row->fachbereich_kurzbz);
|
|
//Koordinator
|
|
$worksheet->write($zeile,++$spalte,$row->koordinator);
|
|
if($maxlength[$spalte]<strlen($row->koordinator))
|
|
$maxlength[$spalte]=strlen($row->koordinator);
|
|
//Lektor
|
|
$worksheet->write($zeile,++$spalte,$mitarbeiter->nachname);
|
|
if($maxlength[$spalte]<strlen($mitarbeiter->nachname))
|
|
$maxlength[$spalte]=strlen($mitarbeiter->nachname);
|
|
//Lehrfach
|
|
$worksheet->write($zeile,++$spalte,$row->lf_bezeichnung);
|
|
if($maxlength[$spalte]<strlen($row->lf_bezeichnung))
|
|
$maxlength[$spalte]=strlen($row->lf_bezeichnung);
|
|
//Semester
|
|
$worksheet->write($zeile,++$spalte,$row->lv_semester);
|
|
if($maxlength[$spalte]<strlen($row->lv_semester))
|
|
$maxlength[$spalte]=strlen($row->lv_semester);
|
|
|
|
$qry = "SELECT * FROM lehre.tbl_lehreinheitgruppe WHERE lehreinheit_id='$row->lehreinheit_id'";
|
|
$result_gruppe = pg_query($conn, $qry);
|
|
$gruppe = '';
|
|
while($row_gruppe = pg_fetch_object($result_gruppe))
|
|
{
|
|
if($gruppe!='')
|
|
$gruppe.=', ';
|
|
if($row_gruppe->gruppe_kurzbz!='')
|
|
$gruppe.=$row_gruppe->gruppe_kurzbz;
|
|
else
|
|
$gruppe.=trim($stg_obj->kuerzel_arr[$row_gruppe->studiengang_kz].'-'.$row_gruppe->semester.$row_gruppe->verband.$row_gruppe->gruppe);
|
|
}
|
|
|
|
//Gruppen
|
|
$worksheet->write($zeile,++$spalte,$gruppe);
|
|
if($maxlength[$spalte]<strlen($gruppe))
|
|
$maxlength[$spalte]=strlen($gruppe);
|
|
//Semesterstunden
|
|
$worksheet->write($zeile,++$spalte,$row->semesterstunden);
|
|
if($maxlength[$spalte]<strlen($row->semesterstunden))
|
|
$maxlength[$spalte]=strlen($row->semesterstunden);
|
|
|
|
$kosten = ($row->stundensatz*$row->semesterstunden*$row->faktor);
|
|
|
|
//Kosten
|
|
$worksheet->write($zeile,++$spalte,$kosten);
|
|
if($maxlength[$spalte]<strlen($kosten))
|
|
$maxlength[$spalte]=strlen($kosten);
|
|
//Planstunden
|
|
$worksheet->write($zeile,++$spalte,$row->planstunden);
|
|
if($maxlength[$spalte]<strlen($row->planstunden))
|
|
$maxlength[$spalte]=strlen($row->planstunden);
|
|
//Stundenblockung
|
|
$worksheet->write($zeile,++$spalte,$row->stundenblockung);
|
|
if($maxlength[$spalte]<strlen($row->stundenblockung))
|
|
$maxlength[$spalte]=strlen($row->stundenblockung);
|
|
//Wochentrythmus
|
|
$worksheet->write($zeile,++$spalte,$row->wochenrythmus);
|
|
if($maxlength[$spalte]<strlen($row->wochenrythmus))
|
|
$maxlength[$spalte]=strlen($row->wochenrythmus);
|
|
//Raumtyp
|
|
$worksheet->write($zeile,++$spalte,$row->raumtyp);
|
|
if($maxlength[$spalte]<strlen($row->raumtyp))
|
|
$maxlength[$spalte]=strlen($row->raumtyp);
|
|
//Raumtypalternativ
|
|
$worksheet->write($zeile,++$spalte,$row->raumtypalternativ);
|
|
if($maxlength[$spalte]<strlen($row->raumtypalternativ))
|
|
$maxlength[$spalte]=strlen($row->raumtypalternativ);
|
|
//Anmerkung
|
|
$worksheet->write($zeile,++$spalte,$row->anmerkung);
|
|
if($maxlength[$spalte]<strlen($row->anmerkung))
|
|
$maxlength[$spalte]=strlen($row->anmerkung);
|
|
}
|
|
|
|
//Betreuungen
|
|
$qry = "SELECT
|
|
tbl_lehrveranstaltung.studiengang_kz, fachbereich_kurzbz,
|
|
(SELECT nachname FROM public.tbl_person JOIN public.tbl_benutzer USING(person_id)
|
|
WHERE uid=COALESCE(koordinator, (SELECT uid FROM public.tbl_benutzerfunktion
|
|
WHERE fachbereich_kurzbz=tbl_lehrfach.fachbereich_kurzbz AND
|
|
studiengang_kz=tbl_lehrveranstaltung.studiengang_kz AND
|
|
funktion_kurzbz='fbk' LIMIT 1
|
|
)
|
|
)
|
|
) as koordinator, nachname, tbl_lehrfach.bezeichnung,
|
|
tbl_lehrveranstaltung.semester, student_uid, stunden, tbl_projektbetreuer.stundensatz,
|
|
tbl_projektbetreuer.faktor
|
|
FROM
|
|
lehre.tbl_projektarbeit, lehre.tbl_lehreinheit, lehre.tbl_lehrveranstaltung,
|
|
lehre.tbl_projektbetreuer, public.tbl_person, lehre.tbl_lehrfach
|
|
WHERE
|
|
tbl_projektarbeit.lehreinheit_id=tbl_lehreinheit.lehreinheit_id AND
|
|
tbl_lehreinheit.lehrveranstaltung_id=tbl_lehrveranstaltung.lehrveranstaltung_id AND
|
|
tbl_projektarbeit.projektarbeit_id=tbl_projektbetreuer.projektarbeit_id AND
|
|
tbl_lehreinheit.lehrfach_id=tbl_lehrfach.lehrfach_id AND
|
|
tbl_person.person_id=tbl_projektbetreuer.person_id AND
|
|
tbl_lehreinheit.studiensemester_kurzbz='$semester_aktuell' AND
|
|
(tbl_projektbetreuer.faktor*tbl_projektbetreuer.stundensatz*tbl_projektbetreuer.stunden)>0
|
|
";
|
|
if($uid!=='')
|
|
{
|
|
$mitarbeiter = new mitarbeiter($conn, $uid);
|
|
$qry.=" AND tbl_projektbetreuer.person_id='$mitarbeiter->person_id'";
|
|
}
|
|
|
|
if($institut!='')
|
|
$qry.=" AND tbl_lehrfach.fachbereich_kurzbz='".addslashes($institut)."'";
|
|
|
|
if($studiengang_kz!='')
|
|
$qry.=" AND tbl_lehrveranstaltung.studiengang_kz='$studiengang_kz'";
|
|
|
|
if($result = pg_query($conn, $qry))
|
|
{
|
|
$spalte=0;
|
|
$zeile++;
|
|
$zeile++;
|
|
$worksheet->write($zeile,$spalte,"Betreuungen", $format_bold);
|
|
|
|
while($row = pg_fetch_object($result))
|
|
{
|
|
$spalte=0;
|
|
$zeile++;
|
|
|
|
//Studiengang
|
|
$worksheet->write($zeile,$spalte,$stg_obj->kuerzel_arr[$row->studiengang_kz]);
|
|
if($maxlength[$spalte]<strlen($stg_obj->kuerzel_arr[$row->studiengang_kz]))
|
|
$maxlength[$spalte]=strlen($stg_obj->kuerzel_arr[$row->studiengang_kz]);
|
|
|
|
//Fachbereich
|
|
$worksheet->write($zeile,++$spalte,$row->fachbereich_kurzbz);
|
|
if($maxlength[$spalte]<strlen($row->fachbereich_kurzbz))
|
|
$maxlength[$spalte]=strlen($row->fachbereich_kurzbz);
|
|
//Koordinator
|
|
$worksheet->write($zeile,++$spalte,$row->koordinator);
|
|
if($maxlength[$spalte]<strlen($row->koordinator))
|
|
$maxlength[$spalte]=strlen($row->koordinator);
|
|
//Lektor
|
|
$worksheet->write($zeile,++$spalte,$row->nachname);
|
|
if($maxlength[$spalte]<strlen($row->nachname))
|
|
$maxlength[$spalte]=strlen($row->nachname);
|
|
//Lehrfach
|
|
$worksheet->write($zeile,++$spalte,$row->bezeichnung);
|
|
if($maxlength[$spalte]<strlen($row->bezeichnung))
|
|
$maxlength[$spalte]=strlen($row->bezeichnung);
|
|
//Semester
|
|
$worksheet->write($zeile,++$spalte,$row->semester);
|
|
if($maxlength[$spalte]<strlen($row->semester))
|
|
$maxlength[$spalte]=strlen($row->semester);
|
|
|
|
$benutzer = new benutzer($conn);
|
|
$benutzer->load($row->student_uid);
|
|
//Student
|
|
$worksheet->write($zeile,++$spalte,$benutzer->nachname.' '.$benutzer->vorname);
|
|
if($maxlength[$spalte]<strlen($benutzer->nachname.' '.$benutzer->vorname))
|
|
$maxlength[$spalte]=strlen($benutzer->nachname.' '.$benutzer->vorname);
|
|
//Stunden
|
|
$worksheet->write($zeile,++$spalte,$row->stunden);
|
|
if($maxlength[$spalte]<strlen($row->stunden))
|
|
$maxlength[$spalte]=strlen($row->stunden);
|
|
//Kosten
|
|
$worksheet->write($zeile,++$spalte,$row->stunden*$row->stundensatz*$row->faktor);
|
|
if($maxlength[$spalte]<strlen($row->stunden*$row->stundensatz*$row->faktor))
|
|
$maxlength[$spalte]=strlen($row->stunden*$row->stundensatz*$row->faktor);
|
|
|
|
}
|
|
}
|
|
|
|
//Die Breite der Spalten setzen
|
|
foreach($maxlength as $i=>$breite)
|
|
$worksheet->setColumn($i, $i, $breite+2);
|
|
}
|
|
$workbook->close();
|
|
?>
|