Studienerfolgsbestätigung fuer alle besuchten Semester drucken

This commit is contained in:
Andreas Österreicher
2007-10-29 10:04:54 +00:00
parent 950a2dd740
commit 824e847648
6 changed files with 172 additions and 116 deletions
+3 -1
View File
@@ -29,7 +29,7 @@
<td align='center'>1</td>
<tr>
<tr class='liste1'>
<td>Studienerfolgsbestaetigung ausdrucken fuer alle Semester die der Student besucht hat</td>
<td></td>
<td align='center'>2</td>
<tr>
</table>
@@ -176,6 +176,8 @@
<hr>
<h2>Erledigte Anforderungen</h2>
<ul>
<li>Studienerfolgsbestaetigung ausdrucken fuer alle Semester die der Student besucht hat<br>
29.10.2007 oesi<br><br></li>
<li>im Filter offene Buchungen scheinen Personen ohne Buchungen (Belastungen) auf<br>
25.10.2007 oesi<br><br></li>
<li>Beim Filtern nach bezahlter Studiengebühr sollen Incoming nicht aufscheinen da diese keine Studiengebühr zahlen müssen<br>
+18
View File
@@ -96,6 +96,8 @@ echo '<?xml-stylesheet href="datepicker/datepicker.css" type="text/css"?>';
<command id="menu-dokumente-diplsupplement:command" oncommand="StudentCreateDiplSupplement();"/>
<command id="menu-dokumente-studienerfolg-normal:command" oncommand="StudentCreateStudienerfolg();"/>
<command id="menu-dokumente-studienerfolg-finanzamt:command" oncommand="StudentCreateStudienerfolg('finanzamt');"/>
<command id="menu-dokumente-studienerfolg-allesemester-normal:command" oncommand="StudentCreateStudienerfolg('', '', 'true');"/>
<command id="menu-dokumente-studienerfolg-allesemester-finanzamt:command" oncommand="StudentCreateStudienerfolg('finanzamt', '', 'true');"/>
<command id="menu-dokumente-accountinfoblatt:command" oncommand="PrintAccountInfoBlatt();"/>
<command id="menu-dokumente-pruefungsprotokoll:command" oncommand="StudentAbschlusspruefungPrintPruefungsprotokollMultiple();"/>
<command id="menu-dokumente-pruefungszeugnis:command" oncommand="StudentAbschlusspruefungPrintPruefungszeugnisMultiple();"/>
@@ -328,6 +330,22 @@ echo '<?xml-stylesheet href="datepicker/datepicker.css" type="text/css"?>';
accesskey = "&menu-dokumente-diplsupplement.accesskey;"/>
<menu id="menu-dokumente-studienerfolg" label="&menu-dokumente-studienerfolg.label;" accesskey="&menu-dokumente-studienerfolg.accesskey;">
<menupopup id="menu-dokumente-studienerfolg-popup">
<menu id="menu-dokumente-studienerfolg-allesemester" label="&menu-dokumente-studienerfolg-allesemester.label;">
<menupopup id="menu-dokumente-studienerfolg-allesemester-popup">
<menuitem
id = "menu-dokumente-studienerfolg-allesemester-normal"
key = "menu-dokumente-studienerfolg-allesemester-normal:key"
label = "&menu-dokumente-studienerfolg-allesemester-normal.label;"
command = "menu-dokumente-studienerfolg-allesemester-normal:command"
accesskey = "&menu-dokumente-studienerfolg-allesemester-normal.accesskey;"/>
<menuitem
id = "menu-dokumente-studienerfolg-allesemester-finanzamt"
key = "menu-dokumente-studienerfolg-allesemester-finanzamt:key"
label = "&menu-dokumente-studienerfolg-allesemester-finanzamt.label;"
command = "menu-dokumente-studienerfolg-allesemester-finanzamt:command"
accesskey = "&menu-dokumente-studienerfolg-allesemester-finanzamt.accesskey;"/>
</menupopup>
</menu>
<?php
$qry = "SELECT studiensemester_kurzbz FROM public.tbl_studiensemester WHERE ende<now() ORDER BY ende DESC LIMIT 5";
+2
View File
@@ -92,6 +92,8 @@ if(isset($_GET['abschlusspruefung_id']))
$params.='&abschlusspruefung_id='.$_GET['abschlusspruefung_id'];
if(isset($_GET['typ']))
$params.='&typ='.$_GET['typ'];
if(isset($_GET['all']))
$params.='&all='.$_GET['all'];
//Berechtigung pruefen
+7 -2
View File
@@ -3618,7 +3618,7 @@ function StudentCreateDiplSupplement()
// ****
// * Erstellt die Studienerfolgsbestaetigung fuer einen oder mehrere Studenten
// ****
function StudentCreateStudienerfolg(finanzamt, studiensemester)
function StudentCreateStudienerfolg(finanzamt, studiensemester, all)
{
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
@@ -3653,8 +3653,13 @@ function StudentCreateStudienerfolg(finanzamt, studiensemester)
}
if(!studiensemester)
studiensemester=getStudiensemester();
if(all=='true')
all='&all=true';
else
all='';
//PDF erzeugen
window.open('<?php echo APP_ROOT; ?>content/pdfExport.php?xml=studienerfolg.rdf.php&xsl=Studienerfolg&uid='+paramList+'&ss='+studiensemester+'&typ='+finanzamt,'DiplomaSupplement', 'height=200,width=350,left=0,top=0,hotkeys=0,resizable=yes,status=no,scrollbars=yes,toolbar=no,location=no,menubar=no,dependent=yes');
window.open('<?php echo APP_ROOT; ?>content/pdfExport.php?xml=studienerfolg.rdf.php&xsl=Studienerfolg&uid='+paramList+'&ss='+studiensemester+'&typ='+finanzamt+all,'DiplomaSupplement', 'height=200,width=350,left=0,top=0,hotkeys=0,resizable=yes,status=no,scrollbars=yes,toolbar=no,location=no,menubar=no,dependent=yes');
}
// ************* FUNKTIONEN ***************** //
+8
View File
@@ -133,6 +133,14 @@
<!ENTITY menu-dokumente-studienerfolg-finanzamt.label "Finanzamt">
<!ENTITY menu-dokumente-studienerfolg-finanzamt.accesskey "F">
<!ENTITY menu-dokumente-studienerfolg-allesemester.label "Alle Semester">
<!ENTITY menu-dokumente-studienerfolg-allesemester-normal.label "Normal">
<!ENTITY menu-dokumente-studienerfolg-allesemester-normal.accesskey "N">
<!ENTITY menu-dokumente-studienerfolg-allesemester-finanzamt.label "Finanzamt">
<!ENTITY menu-dokumente-studienerfolg-allesemester-finanzamt.accesskey "F">
<!ENTITY menu-dokumente-accountinfoblatt.label "Account InfoBlatt">
<!ENTITY menu-dokumente-accountinfoblatt.accesskey "A">
+134 -113
View File
@@ -43,6 +43,121 @@ if (!$conn = pg_pconnect(CONN_STRING))
//loadVariables($conn, $user);
$datum = new datum();
function draw_studienerfolg($uid, $studiensemester_kurzbz)
{
global $conn, $xml, $note_arr, $datum;
$query = "SELECT tbl_student.matrikelnr, tbl_student.studiengang_kz, tbl_studiengang.bezeichnung, tbl_studentlehrverband.semester, tbl_person.titelpre, tbl_person.titelpost, tbl_person.vorname, tbl_person.nachname,tbl_person.gebdatum, tbl_studiensemester.bezeichnung as sembezeichnung FROM public.tbl_person, public.tbl_student, public.tbl_studiengang, public.tbl_benutzer, public.tbl_studentlehrverband, public.tbl_studiensemester WHERE tbl_student.studiengang_kz = tbl_studiengang.studiengang_kz and tbl_student.student_uid = tbl_benutzer.uid and tbl_benutzer.person_id = tbl_person.person_id and tbl_student.student_uid = '".$uid."' and tbl_studentlehrverband.student_uid=tbl_student.student_uid and tbl_studiensemester.studiensemester_kurzbz = tbl_studentlehrverband.studiensemester_kurzbz and tbl_studentlehrverband.studiensemester_kurzbz = '".$studiensemester_kurzbz."'";
if($result = pg_query($conn, $query))
{
if(!$row = pg_fetch_object($result))
return false; //die('Student not found');
}
else
return false; //die('Student not found');
$studiensemester = new studiensemester($conn);
$studiensemester_aktuell = $studiensemester->getNearest();
$semester_aktuell='';
$qry_semester = "SELECT tbl_student.semester FROM public.tbl_student, public.tbl_prestudentrolle WHERE tbl_student.prestudent_id=tbl_prestudentrolle.prestudent_id AND tbl_prestudentrolle.rolle_kurzbz in('Student','Incoming','Outgoing','Praktikant','Diplomand') AND studiensemester_kurzbz='$studiensemester_aktuell' AND tbl_student.student_uid = '".$uid."'";
if($result_semester = pg_query($conn, $qry_semester))
if($row_semester = pg_fetch_object($result_semester))
$semester_aktuell=$row_semester->semester;
if($semester_aktuell=='')
$studiensemester_aktuell='';
$stgl_query = "SELECT titelpre, titelpost, vorname, nachname FROM public.tbl_person, public.tbl_benutzer, public.tbl_benutzerfunktion WHERE tbl_person.person_id = tbl_benutzer.person_id and tbl_benutzer.uid = tbl_benutzerfunktion.uid and tbl_benutzerfunktion.funktion_kurzbz = 'stgl' and tbl_benutzerfunktion.studiengang_kz = '".$row->studiengang_kz."'";
if($stgl_result = pg_query($conn, $stgl_query))
$stgl_row = pg_fetch_object($stgl_result);
else
die('Studiengangsleiter wurde nicht gefunden');
$xml .= " <studienerfolg>";
$xml .= " <studiensemester>".$row->sembezeichnung."</studiensemester>";
$xml .= " <studiensemester_aktuell>".$studiensemester_aktuell."</studiensemester_aktuell>";
$xml .= " <semester>".$row->semester."</semester>";
$xml .= " <semester_aktuell>".$semester_aktuell.($semester_aktuell!=''?'. Semester':'')."</semester_aktuell>";
$xml .= " <studiengang>".$row->bezeichnung."</studiengang>";
$xml .= " <studiengang_kz>".sprintf('%04s',$row->studiengang_kz)."</studiengang_kz>";
$xml .= " <titelpre>".$row->titelpre."</titelpre>";
$xml .= " <titelpost>".$row->titelpost."</titelpost>";
$xml .= " <vorname>".$row->vorname."</vorname>";
$xml .= " <nachname>".$row->nachname."</nachname>";
$gebdatum = date('d.m.Y',strtotime($row->gebdatum));
$xml .= " <gebdatum>".$gebdatum."</gebdatum>";
$xml .= " <matrikelnr>".$row->matrikelnr."</matrikelnr>";
$xml .= " <studiensemester_kurzbz>".$studiensemester_kurzbz."</studiensemester_kurzbz>";
$datum_aktuell = date('d.m.Y');
$xml .= " <datum>".$datum_aktuell."</datum>";
if(isset($_REQUEST['typ']) && $_REQUEST['typ']=='finanzamt')
$xml .= " <finanzamt>(gemäß §2 Abs. 1 lit.b des Familienlastenausgleichsgesetzes 1967 zur Vorlage beim Wohnsitzfinanzamt)</finanzamt>";
else
$xml .= " <finanzamt></finanzamt>";
$obj = new zeugnisnote($conn, null, null, null, false);
$obj->getZeugnisnoten($lehrveranstaltung_id=null, $uid, $studiensemester_kurzbz);
$qry = "SELECT wochen FROM public.tbl_semesterwochen WHERE studiengang_kz='$row->studiengang_kz' AND semester='$row->semester'";
$wochen = 15;
if($result_wochen = pg_query($conn, $qry))
{
if($row_wochen = pg_fetch_object($result_wochen))
{
$wochen = $row_wochen->wochen;
}
}
$gesamtstunden=0;
$gesamtects=0;
$notensumme=0;
$anzahl=0;
foreach ($obj->result as $row)
{
//Note darf nicht teilnote(0), negativ(5), noch nicht eingetragen(7), nicht beurteilt (9), nicht erfolgreich absolviert (13), angerechnet(6) sein
if($row->zeugnis && $row->note!=0 && $row->note!=5 && $row->note!=7 && $row->note!=9 && $row->note!=13 && $row->note!=6)
{
if ($row->note)
$note = $note_arr[$row->note];
else
$note = "";
if($note!='')
{
$xml .= " <unterrichtsfach>";
$xml .= " <bezeichnung><![CDATA[".$row->lehrveranstaltung_bezeichnung."]]></bezeichnung>";
$xml .= " <note>".$note."</note>";
$xml .= " <sws>".sprintf('%.1f',$row->semesterstunden)."</sws>"; ///$wochen
$xml .= " <ects>".$row->ects."</ects>";
if($row->benotungsdatum!='')
$xml .= " <benotungsdatum>".date('d.m.Y',$datum->mktime_fromtimestamp($row->benotungsdatum))."</benotungsdatum>";
$xml .= " </unterrichtsfach>";
$gesamtstunden +=$row->semesterstunden;
$gesamtects += $row->ects;
if(is_numeric($note))
{
$notensumme += $note;
$anzahl++;
}
}
}
}
if($anzahl!=0)
{
$schnitt = ($notensumme/$anzahl);
}
else
$schnitt = 0;
$xml .= " <gesamtstunden>$gesamtstunden</gesamtstunden>";
$xml .= " <gesamtects>$gesamtects</gesamtects>";
$xml .= " <schnitt>".sprintf('%.2f',$schnitt)."</schnitt>";
$xml .= " </studienerfolg>";
}
if (isset($_REQUEST["xmlformat"]) && $_REQUEST["xmlformat"] == "xml")
{
@@ -64,131 +179,37 @@ if (isset($_REQUEST["xmlformat"]) && $_REQUEST["xmlformat"] == "xml")
$note->getAll();
foreach ($note->result as $n)
$note_arr[$n->note] = $n->anmerkung;
if(isset($_GET['ss']))
$studiensemester_kurzbz = $_GET['ss'];
else
$studiensemester_kurzbz = $semester_aktuell;
//$rdf_url='http://www.technikum-wien.at/zeugnisnote';
//Daten holen
$xml = "<?xml version='1.0' encoding='ISO-8859-15' standalone='yes'?>\n";
$xml .= "<studienerfolge>";
for ($i = 0; $i < sizeof($uid_arr); $i++)
{
$query = "SELECT tbl_student.matrikelnr, tbl_student.studiengang_kz, tbl_studiengang.bezeichnung, tbl_studentlehrverband.semester, tbl_person.titelpre, tbl_person.titelpost, tbl_person.vorname, tbl_person.nachname,tbl_person.gebdatum, tbl_studiensemester.bezeichnung as sembezeichnung FROM tbl_person, tbl_student, tbl_studiengang, tbl_benutzer, tbl_studentlehrverband, tbl_studiensemester WHERE tbl_student.studiengang_kz = tbl_studiengang.studiengang_kz and tbl_student.student_uid = tbl_benutzer.uid and tbl_benutzer.person_id = tbl_person.person_id and tbl_student.student_uid = '".$uid_arr[$i]."' and tbl_studentlehrverband.student_uid=tbl_student.student_uid and tbl_studiensemester.studiensemester_kurzbz = tbl_studentlehrverband.studiensemester_kurzbz and tbl_studentlehrverband.studiensemester_kurzbz = '".$studiensemester_kurzbz."'";
if($result = pg_query($conn, $query))
if(isset($_GET['all']))
{
for ($i = 0; $i < sizeof($uid_arr); $i++)
{
if(!$row = pg_fetch_object($result))
die('Student not found');
//Studienbestaetigung fuer alle Semester dieses Studenten
$qry = "SELECT * FROM public.tbl_studiensemester WHERE studiensemester_kurzbz in(SELECT studiensemester_kurzbz FROM public.tbl_prestudentrolle JOIN public.tbl_student USING(prestudent_id) WHERE student_uid='".addslashes($uid_arr[$i])."') ORDER BY start";
if($result = pg_query($conn, $qry))
while($row = pg_fetch_object($result))
draw_studienerfolg($uid_arr[$i], $row->studiensemester_kurzbz);
}
else
die('Student not found');
$studiensemester = new studiensemester($conn);
$studiensemester_aktuell = $studiensemester->getNearest();
$semester_aktuell='';
$qry_semester = "SELECT tbl_student.semester FROM public.tbl_student, public.tbl_prestudentrolle WHERE tbl_student.prestudent_id=tbl_prestudentrolle.prestudent_id AND tbl_prestudentrolle.rolle_kurzbz in('Student','Incoming','Outgoing','Praktikant','Diplomand') AND studiensemester_kurzbz='$studiensemester_aktuell' AND tbl_student.student_uid = '".$uid_arr[$i]."'";
if($result_semester = pg_query($conn, $qry_semester))
if($row_semester = pg_fetch_object($result_semester))
$semester_aktuell=$row_semester->semester;
if($semester_aktuell=='')
$studiensemester_aktuell='';
$stgl_query = "SELECT titelpre, titelpost, vorname, nachname FROM tbl_person, tbl_benutzer, tbl_benutzerfunktion WHERE tbl_person.person_id = tbl_benutzer.person_id and tbl_benutzer.uid = tbl_benutzerfunktion.uid and tbl_benutzerfunktion.funktion_kurzbz = 'stgl' and tbl_benutzerfunktion.studiengang_kz = '".$row->studiengang_kz."'";
if($stgl_result = pg_query($conn, $stgl_query))
$stgl_row = pg_fetch_object($stgl_result);
else
die('Stgl not found');
$xml .= " <studienerfolg>";
$xml .= " <studiensemester>".$row->sembezeichnung."</studiensemester>";
$xml .= " <studiensemester_aktuell>".$studiensemester_aktuell."</studiensemester_aktuell>";
$xml .= " <semester>".$row->semester."</semester>";
$xml .= " <semester_aktuell>".$semester_aktuell.($semester_aktuell!=''?'. Semester':'')."</semester_aktuell>";
$xml .= " <studiengang>".$row->bezeichnung."</studiengang>";
$xml .= " <studiengang_kz>".sprintf('%04s',$row->studiengang_kz)."</studiengang_kz>";
$xml .= " <titelpre>".$row->titelpre."</titelpre>";
$xml .= " <titelpost>".$row->titelpost."</titelpost>";
$xml .= " <vorname>".$row->vorname."</vorname>";
$xml .= " <nachname>".$row->nachname."</nachname>";
$gebdatum = date('d.m.Y',strtotime($row->gebdatum));
$xml .= " <gebdatum>".$gebdatum."</gebdatum>";
$xml .= " <matrikelnr>".$row->matrikelnr."</matrikelnr>";
$xml .= " <studiensemester_kurzbz>".$studiensemester_kurzbz."</studiensemester_kurzbz>";
$datum_aktuell = date('d.m.Y');
$xml .= " <datum>".$datum_aktuell."</datum>";
if(isset($_REQUEST['typ']) && $_REQUEST['typ']=='finanzamt')
$xml .= " <finanzamt>(gemäß §2 Abs. 1 lit.b des Familienlastenausgleichsgesetzes 1967 zur Vorlage beim Wohnsitzfinanzamt)</finanzamt>";
else
$xml .= " <finanzamt></finanzamt>";
$obj = new zeugnisnote($conn, null, null, null, false);
$obj->getZeugnisnoten($lehrveranstaltung_id=null, $uid_arr[$i], $studiensemester_kurzbz);
$qry = "SELECT wochen FROM public.tbl_semesterwochen WHERE studiengang_kz='$row->studiengang_kz' AND semester='$row->semester'";
$wochen = 15;
if($result_wochen = pg_query($conn, $qry))
{
if($row_wochen = pg_fetch_object($result_wochen))
{
$wochen = $row_wochen->wochen;
}
}
$gesamtstunden=0;
$gesamtects=0;
$notensumme=0;
$anzahl=0;
foreach ($obj->result as $row)
{
//Note darf nicht teilnote(0), negativ(5), noch nicht eingetragen(7), nicht beurteilt (9), nicht erfolgreich absolviert (13), angerechnet(6) sein
if($row->zeugnis && $row->note!=0 && $row->note!=5 && $row->note!=7 && $row->note!=9 && $row->note!=13 && $row->note!=6)
{
if ($row->note)
$note = $note_arr[$row->note];
else
$note = "";
if($note!='')
{
$xml .= " <unterrichtsfach>";
$xml .= " <bezeichnung><![CDATA[".$row->lehrveranstaltung_bezeichnung."]]></bezeichnung>";
$xml .= " <note>".$note."</note>";
$xml .= " <sws>".sprintf('%.1f',$row->semesterstunden)."</sws>"; ///$wochen
$xml .= " <ects>".$row->ects."</ects>";
if($row->benotungsdatum!='')
$xml .= " <benotungsdatum>".date('d.m.Y',$datum->mktime_fromtimestamp($row->benotungsdatum))."</benotungsdatum>";
$xml .= " </unterrichtsfach>";
$gesamtstunden +=$row->semesterstunden;
$gesamtects += $row->ects;
if(is_numeric($note))
{
$notensumme += $note;
$anzahl++;
}
}
}
}
if($anzahl!=0)
{
$schnitt = ($notensumme/$anzahl);
}
else
$schnitt = 0;
$xml .= " <gesamtstunden>$gesamtstunden</gesamtstunden>";
$xml .= " <gesamtects>$gesamtects</gesamtects>";
$xml .= " <schnitt>".sprintf('%.2f',$schnitt)."</schnitt>";
$xml .= " </studienerfolg>";
}
else
{
//Studienbestaetigung fuer ein bestimmtes Semester
for ($i = 0; $i < sizeof($uid_arr); $i++)
{
draw_studienerfolg($uid_arr[$i], $studiensemester_kurzbz);
}
}
$xml .= "</studienerfolge>";
echo $xml;
}