mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 20:29:29 +00:00
736 lines
20 KiB
PHP
736 lines
20 KiB
PHP
<?php
|
|
/* Copyright (C) 2009 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
|
|
* Gerald Simane-Sequens <gerald.simane-sequens@technikum-wien.at>.
|
|
*/
|
|
/**
|
|
* Exportiert die Daten von Prestudenten und Studenten in ein Excel File.
|
|
*
|
|
* Parameter:
|
|
* GET:
|
|
* studiensemester_kurzbz ... Studiensemester
|
|
* POST:
|
|
* data ... Liste der PrestudentIDs der Personen die im Export aufscheinen sollen getrennt durch ','
|
|
*/
|
|
require_once('../../config/vilesci.config.inc.php');
|
|
require_once('../../include/functions.inc.php');
|
|
require_once('../../include/person.class.php');
|
|
require_once('../../include/benutzer.class.php');
|
|
require_once('../../include/student.class.php');
|
|
require_once('../../include/prestudent.class.php');
|
|
require_once('../../include/statusgrund.class.php');
|
|
require_once('../../include/datum.class.php');
|
|
require_once('../../include/Excel/excel.php');
|
|
require_once('../../include/udf.class.php');
|
|
|
|
$user = get_uid();
|
|
$datum_obj = new datum();
|
|
$db = new basis_db();
|
|
loadVariables($user);
|
|
|
|
//Parameter holen
|
|
$data = $_REQUEST['data'];
|
|
$studiensemester_kurzbz = $_GET['studiensemester_kurzbz'];
|
|
|
|
$maxlength = array();
|
|
$zeile = 1;
|
|
$zgv_arr = array();
|
|
$zgvmas_arr = array();
|
|
|
|
//ZGV laden
|
|
$qry = "SELECT * FROM bis.tbl_zgv ORDER BY zgv_kurzbz";
|
|
if ($result = $db->db_query($qry))
|
|
{
|
|
while($row = $db->db_fetch_object($result))
|
|
{
|
|
$zgv_arr[$row->zgv_code] = $row->zgv_kurzbz;
|
|
}
|
|
}
|
|
|
|
//ZGV Master laden
|
|
$qry = "SELECT * FROM bis.tbl_zgvmaster ORDER BY zgvmas_kurzbz";
|
|
if ($result = $db->db_query($qry))
|
|
{
|
|
while($row = $db->db_fetch_object($result))
|
|
{
|
|
$zgvmas_arr[$row->zgvmas_code] = $row->zgvmas_kurzbz;
|
|
}
|
|
}
|
|
|
|
// Creating a workbook
|
|
$workbook = new Spreadsheet_Excel_Writer();
|
|
$workbook->setVersion(8);
|
|
|
|
// sending HTTP headers
|
|
$workbook->send("Studenten". "_" . date("d_m_Y") . ".xls");
|
|
|
|
// Creating a worksheet
|
|
$worksheet =& $workbook->addWorksheet("Studenten");
|
|
$worksheet->setInputEncoding('utf-8');
|
|
|
|
$format_bold =& $workbook->addFormat();
|
|
$format_bold->setBold();
|
|
|
|
$format_title =& $workbook->addFormat();
|
|
$format_title->setBold();
|
|
// let's merge
|
|
$format_title->setAlign('merge');
|
|
|
|
//Zeilenueberschriften ausgeben
|
|
$i = 0;
|
|
$zeile = 0;
|
|
|
|
$worksheet->write($zeile, $i, "ANREDE", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
$worksheet->write($zeile, ++$i, "TITELPRE", $format_bold);
|
|
$maxlength[$i] = 8;
|
|
$worksheet->write($zeile, ++$i, "NACHNAME", $format_bold);
|
|
$maxlength[$i] = 8;
|
|
$worksheet->write($zeile, ++$i, "VORNAME", $format_bold);
|
|
$maxlength[$i] = 7;
|
|
$worksheet->write($zeile, ++$i, "TITELPOST", $format_bold);
|
|
$maxlength[$i] = 9;
|
|
$worksheet->write($zeile, ++$i, "EMail Privat", $format_bold);
|
|
$maxlength[$i] = 12;
|
|
$worksheet->write($zeile,++$i,"STRASSE (Zustelladresse)", $format_bold);
|
|
$maxlength[$i]=12;
|
|
$worksheet->write($zeile,++$i,"PLZ", $format_bold);
|
|
$maxlength[$i]=3;
|
|
$worksheet->write($zeile,++$i,"ORT", $format_bold);
|
|
$maxlength[$i]=3;
|
|
$worksheet->write($zeile,++$i,"GEMEINDE", $format_bold);
|
|
$maxlength[$i]=9;
|
|
$worksheet->write($zeile,++$i,"NATION", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
$worksheet->write($zeile, ++$i, "GEBURTSDATUM", $format_bold);
|
|
$maxlength[$i] = 12;
|
|
$worksheet->write($zeile, ++$i, "PERSONENKENNZEICHEN", $format_bold);
|
|
$maxlength[$i] = 19;
|
|
$worksheet->write($zeile, ++$i, "STAATSBÜRGERSCHAFT", $format_bold);
|
|
$maxlength[$i] = 16;
|
|
$worksheet->write($zeile, ++$i, "PERSON_ID", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
$worksheet->write($zeile, ++$i, "ERSATZKENNZEICHEN", $format_bold);
|
|
$maxlength[$i] = 17;
|
|
$worksheet->write($zeile, ++$i, "GESCHLECHT", $format_bold);
|
|
$maxlength[$i] = 10;
|
|
$worksheet->write($zeile, ++$i, "STUDIENGANG", $format_bold);
|
|
$maxlength[$i] = 11;
|
|
$worksheet->write($zeile, ++$i, "SEMESTER IM $studiensemester_kurzbz", $format_bold);
|
|
$maxlength[$i] = 19;
|
|
$worksheet->write($zeile, ++$i, "SEMESTER AKTUELL", $format_bold);
|
|
$maxlength[$i] = 17;
|
|
$worksheet->write($zeile, ++$i, "VERBAND", $format_bold);
|
|
$maxlength[$i] = 7;
|
|
$worksheet->write($zeile, ++$i, "GRUPPE", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
|
|
$worksheet->write($zeile, ++$i, "ZGV", $format_bold);
|
|
$maxlength[$i] = 10;
|
|
$worksheet->write($zeile, ++$i, "ZGV Ort", $format_bold);
|
|
$maxlength[$i] = 14;
|
|
$worksheet->write($zeile, ++$i, "ZGV Datum", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
$worksheet->write($zeile, ++$i, "ZGV Master", $format_bold);
|
|
$maxlength[$i] = 10;
|
|
$worksheet->write($zeile, ++$i, "ZGV Master Ort", $format_bold);
|
|
$maxlength[$i] = 14;
|
|
$worksheet->write($zeile, ++$i, "ZGV Master Datum", $format_bold);
|
|
$maxlength[$i] = 16;
|
|
|
|
$worksheet->write($zeile, ++$i, "STATUS", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
$worksheet->write($zeile, ++$i, "STATUSGRUND", $format_bold);
|
|
$maxlength[$i] = 6;
|
|
$worksheet->write($zeile, ++$i, "STATUS IN ANDEREN STUDIENGÄNGEN", $format_bold);
|
|
$maxlength[$i] = 8;
|
|
$worksheet->write($zeile, ++$i, "EMail Intern", $format_bold);
|
|
$maxlength[$i] = 12;
|
|
$worksheet->write($zeile, ++$i, "TELEFON", $format_bold);
|
|
$maxlength[$i] = 3;
|
|
$worksheet->write($zeile, ++$i, "GRUPPEN", $format_bold);
|
|
$maxlength[$i] = 3;
|
|
$worksheet->write($zeile, ++$i, "UID", $format_bold);
|
|
$maxlength[$i] = 3;
|
|
$worksheet->write($zeile, ++$i, "ORGFORM", $format_bold);
|
|
$maxlength[$i] = 7;
|
|
$worksheet->write($zeile, ++$i, "VORNAMEN", $format_bold);
|
|
$maxlength[$i] = 8;
|
|
$worksheet->write($zeile, ++$i, "RT_PUNKTE1", $format_bold);
|
|
$maxlength[$i] = 10;
|
|
$worksheet->write($zeile, ++$i, "RT_PUNKTE2", $format_bold);
|
|
$maxlength[$i] = 10;
|
|
$worksheet->write($zeile, ++$i, "RT_GESAMTPUNKTE", $format_bold);
|
|
$maxlength[$i] = 18;
|
|
$worksheet->write($zeile,++$i,"ANMERKUNG", $format_bold);
|
|
$maxlength[$i]=30;
|
|
$worksheet->write($zeile, ++$i, "PRIORITÄT", $format_bold);
|
|
$maxlength[$i] = 8;
|
|
|
|
// UDF titles
|
|
$udf = new UDF();
|
|
$udfTitlesPerson = $udf->getTitlesPerson();
|
|
$udfTitlesPrestudent = $udf->getTitlesPrestudent();
|
|
|
|
foreach($udfTitlesPerson as $udfTitle)
|
|
{
|
|
$worksheet->write($zeile, ++$i, $udfTitle['description'], $format_bold);
|
|
$maxlength[$i] = mb_strlen($udfTitle['description']);
|
|
}
|
|
|
|
foreach($udfTitlesPrestudent as $udfTitle)
|
|
{
|
|
$worksheet->write($zeile, ++$i, $udfTitle['description'], $format_bold);
|
|
$maxlength[$i] = mb_strlen($udfTitle['description']);
|
|
}
|
|
|
|
$zeile++;
|
|
|
|
$ids = explode(';',$data);
|
|
$prestudent_ids = '';
|
|
|
|
foreach ($ids as $id)
|
|
{
|
|
if ($id!='')
|
|
{
|
|
if ($prestudent_ids!='')
|
|
$prestudent_ids .= ',';
|
|
$prestudent_ids .= "'".$db->db_escape($id)."'";
|
|
}
|
|
}
|
|
|
|
if ($prestudent_ids!='')
|
|
{
|
|
// Student holen
|
|
$qry = "SELECT *,";
|
|
|
|
if ($udf->personHasUDF())
|
|
{
|
|
$qry .= " p.udf_values AS p_udf_values,";
|
|
}
|
|
if ($udf->prestudentHasUDF())
|
|
{
|
|
$qry .= " ps.udf_values AS ps_udf_values,";
|
|
}
|
|
|
|
$qry .= " ps.studiengang_kz AS prestgkz,
|
|
(
|
|
SELECT UPPER(typ || kurzbz)
|
|
FROM public.tbl_studiengang s
|
|
WHERE studiengang_kz = ps.studiengang_kz
|
|
) AS stgbez
|
|
FROM public.tbl_prestudent ps
|
|
JOIN public.tbl_person p USING(person_id)
|
|
LEFT JOIN public.tbl_student s USING(prestudent_id)
|
|
WHERE prestudent_id IN($prestudent_ids)
|
|
ORDER BY nachname, vorname";
|
|
|
|
if ($db->db_query($qry))
|
|
{
|
|
while($row = $db->db_fetch_object())
|
|
{
|
|
draw_content($row);
|
|
$zeile++;
|
|
}
|
|
}
|
|
}
|
|
|
|
function draw_content($row)
|
|
{
|
|
global $maxlength, $datum_obj;
|
|
global $zeile, $worksheet;
|
|
global $zgv_arr, $zgvmas_arr;
|
|
global $studiensemester_kurzbz;
|
|
global $udfTitlesPerson, $udfTitlesPrestudent, $udf;
|
|
$db = new basis_db();
|
|
|
|
$prestudent = new prestudent();
|
|
$prestudent->getLastStatus($row->prestudent_id);
|
|
$statusgrundObj = new statusgrund($prestudent->statusgrund_id);
|
|
$statusgrund = $statusgrundObj->bezeichnung_mehrsprachig[DEFAULT_LANGUAGE];
|
|
$status = $prestudent->status_kurzbz;
|
|
$orgform = $prestudent->orgform_kurzbz;
|
|
$prio_relativ = new prestudent();
|
|
$prio_relativ = $prio_relativ->getRelativePriorisierungFromAbsolut($row->prestudent_id, $row->priorisierung);
|
|
|
|
$i = 0;
|
|
|
|
//Anrede
|
|
if (mb_strlen($row->anrede) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->anrede);
|
|
$worksheet->write($zeile, $i, $row->anrede);
|
|
$i++;
|
|
|
|
//Titelpre
|
|
if (mb_strlen($row->titelpre) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->titelpre);
|
|
$worksheet->write($zeile, $i, $row->titelpre);
|
|
$i++;
|
|
|
|
//Nachname
|
|
if (mb_strlen($row->nachname) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->nachname);
|
|
$worksheet->write($zeile, $i, $row->nachname);
|
|
$i++;
|
|
|
|
//Vorname
|
|
if (mb_strlen($row->vorname) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->vorname);
|
|
$worksheet->write($zeile, $i, $row->vorname);
|
|
$i++;
|
|
|
|
//Titelpost
|
|
if (mb_strlen($row->titelpost) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->titelpost);
|
|
$worksheet->write($zeile, $i, $row->titelpost);
|
|
$i++;
|
|
|
|
//Email Privat
|
|
//ZustellEmailAdresse aus der Datenbank holen und dazuhaengen
|
|
$qry_1 = "
|
|
SELECT
|
|
kontakt
|
|
FROM
|
|
public.tbl_kontakt
|
|
WHERE
|
|
kontakttyp='email'
|
|
AND person_id=".$db->db_add_param($row->person_id)."
|
|
AND zustellung=true
|
|
ORDER BY kontakt_id DESC
|
|
LIMIT 1";
|
|
|
|
if ($db->db_query($qry_1))
|
|
{
|
|
if ($row_1 = $db->db_fetch_object())
|
|
{
|
|
if (mb_strlen($row_1->kontakt) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row_1->kontakt);
|
|
$worksheet->write($zeile, $i, $row_1->kontakt);
|
|
}
|
|
}
|
|
$i++;
|
|
|
|
//Zustelladresse
|
|
//Zustelladresse aus der Datenbank holen und dazuhaengen
|
|
$qry_1 = "
|
|
SELECT
|
|
*
|
|
FROM
|
|
public.tbl_adresse
|
|
WHERE
|
|
person_id=".$db->db_add_param($row->person_id)."
|
|
AND zustelladresse=true LIMIT 1";
|
|
|
|
if($result_1 = $db->db_query($qry_1))
|
|
{
|
|
if($row_1 = $db->db_fetch_object($result_1))
|
|
{
|
|
if(mb_strlen($row_1->strasse)>$maxlength[$i])
|
|
$maxlength[$i]=mb_strlen($row_1->strasse);
|
|
$worksheet->write($zeile,$i, $row_1->strasse);
|
|
$i++;
|
|
|
|
if(mb_strlen($row_1->plz)>$maxlength[$i])
|
|
$maxlength[$i]=mb_strlen($row_1->plz);
|
|
$worksheet->writeString($zeile,$i, $row_1->plz);
|
|
$i++;
|
|
|
|
if(mb_strlen($row_1->ort)>$maxlength[$i])
|
|
$maxlength[$i]=mb_strlen($row_1->ort);
|
|
$worksheet->write($zeile,$i, $row_1->ort);
|
|
$i++;
|
|
|
|
if(mb_strlen($row_1->gemeinde)>$maxlength[$i])
|
|
$maxlength[$i]=mb_strlen($row_1->gemeinde);
|
|
$worksheet->write($zeile,$i, $row_1->gemeinde);
|
|
$i++;
|
|
|
|
if(mb_strlen($row_1->nation)>$maxlength[$i])
|
|
$maxlength[$i]=mb_strlen($row_1->nation);
|
|
$worksheet->write($zeile,$i, $row_1->nation);
|
|
$i++;
|
|
}
|
|
else
|
|
$i+=5;
|
|
}
|
|
else
|
|
$i+=5;
|
|
|
|
//Geburtsdatum
|
|
if (mb_strlen($row->gebdatum) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->gebdatum);
|
|
$worksheet->write($zeile, $i, $datum_obj->convertISODate($row->gebdatum));
|
|
$i++;
|
|
|
|
//Personenkennzeichen
|
|
if (isset($row->matrikelnr))
|
|
{
|
|
if (mb_strlen($row->matrikelnr) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->matrikelnr);
|
|
$worksheet->writeString($zeile, $i, $row->matrikelnr);
|
|
}
|
|
$i++;
|
|
|
|
//Staatsbuergerschaft
|
|
if (mb_strlen($row->staatsbuergerschaft) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->staatsbuergerschaft);
|
|
$worksheet->write($zeile, $i, $row->staatsbuergerschaft);
|
|
$i++;
|
|
|
|
|
|
//Person_id
|
|
if (mb_strlen($row->person_id) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->person_id);
|
|
$worksheet->write($zeile, $i, $row->person_id);
|
|
$i++;
|
|
|
|
//Ersatzkennzeichen
|
|
if (mb_strlen($row->ersatzkennzeichen) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->ersatzkennzeichen);
|
|
$worksheet->write($zeile, $i, $row->ersatzkennzeichen);
|
|
$i++;
|
|
|
|
//Geschlecht
|
|
if (mb_strlen($row->geschlecht) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->geschlecht);
|
|
$worksheet->write($zeile, $i, $row->geschlecht);
|
|
$i++;
|
|
|
|
//Studiengang
|
|
if (mb_strlen($row->stgbez) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->stgbez);
|
|
$worksheet->write($zeile, $i, $row->stgbez);
|
|
$i++;
|
|
|
|
$qry = "
|
|
SELECT
|
|
tbl_studentlehrverband.semester AS semester_studiensemester,
|
|
tbl_student.semester AS semester_aktuell,
|
|
*
|
|
FROM
|
|
public.tbl_studentlehrverband
|
|
JOIN public.tbl_student USING(student_uid)
|
|
WHERE
|
|
prestudent_id=".$db->db_add_param($row->prestudent_id)."
|
|
AND studiensemester_kurzbz=".$db->db_add_param($studiensemester_kurzbz);
|
|
|
|
if ($db->db_query($qry))
|
|
{
|
|
if ($row_sem = $db->db_fetch_object())
|
|
{
|
|
$semester_aktuell = $row_sem->semester_aktuell;
|
|
$semester_studiensemester = $row_sem->semester_studiensemester;
|
|
$verband = $row_sem->verband;
|
|
$gruppe = $row_sem->gruppe;
|
|
}
|
|
else
|
|
{
|
|
$semester_aktuell = '';
|
|
$verband = '';
|
|
$gruppe = '';
|
|
}
|
|
}
|
|
//Semester im eingestellten Studiensemester
|
|
if (isset($semester_studiensemester))
|
|
{
|
|
if (mb_strlen($semester_studiensemester) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($semester_studiensemester);
|
|
$worksheet->write($zeile, $i, $semester_studiensemester);
|
|
}
|
|
$i++;
|
|
|
|
//Semester aktuell
|
|
if (isset($semester_aktuell))
|
|
{
|
|
if (mb_strlen($semester_aktuell) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($semester_aktuell);
|
|
$worksheet->write($zeile, $i, $semester_aktuell);
|
|
}
|
|
$i++;
|
|
|
|
//Verband
|
|
if (isset($verband))
|
|
{
|
|
if (mb_strlen($verband) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($verband);
|
|
$worksheet->write($zeile, $i, $verband);
|
|
}
|
|
$i++;
|
|
|
|
//Gruppe
|
|
if (isset($gruppe))
|
|
{
|
|
if (mb_strlen($gruppe) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($gruppe);
|
|
$worksheet->write($zeile, $i, $gruppe);
|
|
}
|
|
$i++;
|
|
|
|
//ZGV
|
|
if ($row->zgv_code!='' && isset($zgv_arr[$row->zgv_code]))
|
|
{
|
|
if (mb_strlen($zgv_arr[$row->zgv_code]) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($zgv_arr[$row->zgv_code]);
|
|
$worksheet->write($zeile, $i, $zgv_arr[$row->zgv_code]);
|
|
}
|
|
$i++;
|
|
|
|
//ZGV Ort
|
|
if (mb_strlen($row->zgvort) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->zgvort);
|
|
$worksheet->write($zeile, $i, $row->zgvort);
|
|
$i++;
|
|
|
|
//ZGV Datum
|
|
if (mb_strlen($row->zgvdatum) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->zgvdatum);
|
|
$worksheet->write($zeile, $i, $row->zgvdatum);
|
|
$i++;
|
|
|
|
//ZGV Master
|
|
if ($row->zgvmas_code!='' && isset($zgvmas_arr[$row->zgvmas_code]))
|
|
{
|
|
if (mb_strlen($zgvmas_arr[$row->zgvmas_code]) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($zgvmas_arr[$row->zgvmas_code]);
|
|
$worksheet->write($zeile, $i, $zgvmas_arr[$row->zgvmas_code]);
|
|
}
|
|
$i++;
|
|
|
|
//ZGV Master Ort
|
|
if (mb_strlen($row->zgvmaort) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->zgvmaort);
|
|
$worksheet->write($zeile, $i, $row->zgvmaort);
|
|
$i++;
|
|
|
|
//ZGV Master Datum
|
|
if (mb_strlen($row->zgvmadatum) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->zgvmadatum);
|
|
$worksheet->write($zeile, $i, $row->zgvmadatum);
|
|
$i++;
|
|
|
|
//Status
|
|
if (mb_strlen($status) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($status);
|
|
$worksheet->write($zeile, $i, $status);
|
|
$i++;
|
|
|
|
//Statusgrund
|
|
if (mb_strlen($statusgrund) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($statusgrund);
|
|
$worksheet->write($zeile, $i, $statusgrund);
|
|
$i++;
|
|
|
|
//Stati in anderen Studiengaengen
|
|
$stati='';
|
|
$qry_1 = "
|
|
SELECT
|
|
UPPER(typ::varchar(1) || kurzbz) as stg,
|
|
get_rolle_prestudent(prestudent_id, null) as status
|
|
FROM
|
|
public.tbl_prestudent
|
|
JOIN public.tbl_studiengang USING(studiengang_kz)
|
|
WHERE
|
|
person_id=".$db->db_add_param($row->person_id)."
|
|
AND tbl_prestudent.studiengang_kz<>".$db->db_add_param($row->prestgkz);
|
|
|
|
if ($db->db_query($qry_1))
|
|
{
|
|
while($row_1 = $db->db_fetch_object())
|
|
{
|
|
if ($stati!='')
|
|
$stati.=', ';
|
|
$stati.= $row_1->status.' ('.$row_1->stg.')';
|
|
}
|
|
}
|
|
if (mb_strlen($stati) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($stati);
|
|
$worksheet->write($zeile, $i, $stati);
|
|
$i++;
|
|
|
|
//Email Intern
|
|
if (isset($row->student_uid))
|
|
{
|
|
if (mb_strlen($row->student_uid.'@'.DOMAIN) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->student_uid.'@'.DOMAIN);
|
|
$worksheet->write($zeile, $i, $row->student_uid.'@'.DOMAIN);
|
|
}
|
|
$i++;
|
|
|
|
//Telefon
|
|
$qry_1 = "
|
|
SELECT
|
|
kontakt
|
|
FROM
|
|
public.tbl_kontakt
|
|
WHERE
|
|
kontakttyp in('mobil','telefon','so.tel')
|
|
AND person_id=".$db->db_add_param($row->person_id)."
|
|
AND zustellung=true
|
|
LIMIT 1";
|
|
|
|
if ($db->db_query($qry_1))
|
|
{
|
|
if ($row_1 = $db->db_fetch_object())
|
|
{
|
|
if (mb_strlen($row_1->kontakt) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row_1->kontakt);
|
|
$worksheet->writeString($zeile, $i, $row_1->kontakt);
|
|
}
|
|
}
|
|
$i++;
|
|
|
|
//Spezialgruppen
|
|
$grps='';
|
|
$qry_1 = "
|
|
SELECT
|
|
gruppe_kurzbz
|
|
FROM
|
|
public.tbl_student
|
|
JOIN public.tbl_benutzergruppe ON (student_uid=uid)
|
|
WHERE
|
|
tbl_student.prestudent_id=".$db->db_add_param($row->prestudent_id)."
|
|
AND tbl_benutzergruppe.studiensemester_kurzbz=".$db->db_add_param($studiensemester_kurzbz);
|
|
|
|
if ($db->db_query($qry_1))
|
|
{
|
|
while($row_1 = $db->db_fetch_object())
|
|
{
|
|
if ($grps!='')
|
|
$grps.=',';
|
|
|
|
$grps.=$row_1->gruppe_kurzbz;
|
|
}
|
|
}
|
|
if (mb_strlen($grps) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($grps);
|
|
$worksheet->write($zeile, $i, $grps);
|
|
$i++;
|
|
|
|
//UID
|
|
if (isset($row->student_uid))
|
|
{
|
|
if (mb_strlen($row->student_uid) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->student_uid);
|
|
$worksheet->write($zeile, $i, $row->student_uid);
|
|
}
|
|
$i++;
|
|
|
|
//Orgform
|
|
if (mb_strlen($orgform) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($orgform);
|
|
$worksheet->write($zeile, $i, $orgform);
|
|
$i++;
|
|
|
|
//Vornamen
|
|
if (mb_strlen($row->vornamen) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->vornamen);
|
|
$worksheet->write($zeile, $i, $row->vornamen);
|
|
$i++;
|
|
|
|
|
|
//RT_Punkte1
|
|
if (mb_strlen($row->rt_punkte1) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->rt_punkte1);
|
|
$worksheet->write($zeile, $i, $row->rt_punkte1);
|
|
$i++;
|
|
|
|
//RT_Punkte2
|
|
if (mb_strlen($row->rt_punkte2) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->rt_punkte2);
|
|
$worksheet->write($zeile, $i, $row->rt_punkte2);
|
|
$i++;
|
|
|
|
//RT_Gesamtpunkte
|
|
if (mb_strlen($row->rt_gesamtpunkte) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($row->rt_gesamtpunkte);
|
|
$worksheet->write($zeile, $i, $row->rt_gesamtpunkte);
|
|
$i++;
|
|
|
|
//Anmerkung
|
|
$qry_1 = "SELECT anmerkung FROM public.tbl_prestudent WHERE prestudent_id=".$db->db_add_param($row->prestudent_id)." LIMIT 1";
|
|
|
|
if($db->db_query($qry_1))
|
|
{
|
|
if($row_1 = $db->db_fetch_object())
|
|
{
|
|
if(mb_strlen($row_1->anmerkung)>$maxlength[$i])
|
|
$maxlength[$i]=mb_strlen($row_1->anmerkung);
|
|
|
|
$worksheet->write($zeile,$i, $row_1->anmerkung);
|
|
}
|
|
}
|
|
$i++;
|
|
//Priorisierung
|
|
$prio = $prio_relativ.' ('.$row->priorisierung.')';
|
|
if (mb_strlen($prio) > $maxlength[$i])
|
|
$maxlength[$i] = mb_strlen($prio);
|
|
$worksheet->write($zeile, $i, $prio);
|
|
$i++;
|
|
|
|
// UDF
|
|
if (isset($row->p_udf_values))
|
|
{
|
|
$udfPerson = json_decode($row->p_udf_values);
|
|
if (is_object($udfPerson)) $udfPerson = (array)$udfPerson;
|
|
|
|
foreach ($udfTitlesPerson as $udfTitle)
|
|
{
|
|
$toWrite = $udf->encodeToString($udfPerson, $udfTitle);
|
|
|
|
if (mb_strlen($toWrite) > $maxlength[$i])
|
|
{
|
|
$maxlength[$i] = mb_strlen($toWrite);
|
|
}
|
|
|
|
$worksheet->write($zeile, $i, $toWrite);
|
|
|
|
$i++;
|
|
}
|
|
}
|
|
|
|
if (isset($row->ps_udf_values))
|
|
{
|
|
$udfPrestudent = json_decode($row->ps_udf_values);
|
|
if (is_object($udfPrestudent)) $udfPrestudent = (array)$udfPrestudent;
|
|
|
|
foreach ($udfTitlesPrestudent as $udfTitle)
|
|
{
|
|
$toWrite = $udf->encodeToString($udfPrestudent, $udfTitle);
|
|
|
|
if (mb_strlen($toWrite) > $maxlength[$i])
|
|
{
|
|
$maxlength[$i] = mb_strlen($toWrite);
|
|
}
|
|
|
|
$worksheet->write($zeile, $i, $toWrite);
|
|
|
|
$i++;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Die Breite der Spalten setzen
|
|
foreach($maxlength as $i => $breite)
|
|
$worksheet->setColumn($i, $i, $breite + 2);
|
|
|
|
$workbook->close();
|
|
|
|
?>
|