mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-11 09:09:28 +00:00
This commit is contained in:
@@ -0,0 +1,99 @@
|
||||
<?php
|
||||
/* Copyright (C) 2006 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> and
|
||||
* Rudolf Hangl <rudolf.hangl@technikum-wien.at>.
|
||||
*/
|
||||
require_once('../../config.inc.php');
|
||||
require_once('../../../include/ort.class.php');
|
||||
require_once('../../../include/raumtyp.class.php');
|
||||
require_once('../../../include/datum.class.php');
|
||||
|
||||
if(!$conn = pg_pconnect(CONN_STRING))
|
||||
die('Fehler beim Connecten zur Datenbank');
|
||||
|
||||
$datum = (isset($_POST['datum'])?$_POST['datum']:date('d.m.Y'));
|
||||
$vonzeit = (isset($_POST['vonzeit'])?$_POST['vonzeit']:date('H:i'));
|
||||
$biszeit = (isset($_POST['biszeit'])?$_POST['biszeit']:date('H:i', mktime(date('H')+1,date('i'))));
|
||||
$raumtyp = (isset($_POST['raumtyp'])?$_POST['raumtyp']:'');
|
||||
$anzahlpersonen = (isset($_POST['anzahlpersonen'])?$_POST['anzahlpersonen']:'');
|
||||
$sent = true; //isset($_POST['sent']);
|
||||
$datum_obj = new datum();
|
||||
|
||||
echo '
|
||||
<html>
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
|
||||
<title>Reservierungsliste</title>
|
||||
<link rel="stylesheet" href="../../../skin/style.css.php" type="text/css">
|
||||
</head>
|
||||
<body id="inhalt">
|
||||
<H2><table class="tabcontent">
|
||||
<tr>
|
||||
<td> <a class="Item" href="index.php">Lehrveranstaltungsplan</a> >> Raumsuche</td>
|
||||
<td align="right"></td>
|
||||
</tr>
|
||||
</table>
|
||||
</H2>
|
||||
';
|
||||
|
||||
echo '<form action="'.$_SERVER['PHP_SELF'].'" method="POST">
|
||||
Datum* <input type="text" name="datum" size="10" value="'.$datum.'">
|
||||
Von* <input type="text" name="vonzeit" size="5" value="'.$vonzeit.'">
|
||||
Bis* <input type="text" name="biszeit" size="5" value="'.$biszeit.'">
|
||||
Raumtyp: <SELECT name="raumtyp">
|
||||
<OPTION value="">Alle</OPTION>';
|
||||
$raumtyp_obj = new raumtyp($conn);
|
||||
$raumtyp_obj->getAll();
|
||||
|
||||
foreach ($raumtyp_obj->result as $row)
|
||||
{
|
||||
if($raumtyp==$row->raumtyp_kurzbz)
|
||||
$selected='selected';
|
||||
else
|
||||
$selected='';
|
||||
|
||||
echo '<OPTION value="'.$row->raumtyp_kurzbz.'" '.$selected.'>'.$row->raumtyp_kurzbz.'</OPTION>';
|
||||
}
|
||||
echo ' </SELECT>
|
||||
Anzahl Personen <input type="text" size="3" name="anzahlpersonen" value="'.$anzahlpersonen.'">
|
||||
<input type="submit" name="sent" value="Suchen" />
|
||||
</form>';
|
||||
if($sent)
|
||||
{
|
||||
$ort = new ort($conn);
|
||||
$ort->search($datum, $vonzeit, $biszeit, $raumtyp, $anzahlpersonen, true);
|
||||
|
||||
echo '<br><table>';
|
||||
echo '<tr class="liste"><td>Raum</td><td>Bezeichnung</td><td>Nummer</td><td>Personen</td><td>Reservieren</td></tr>';
|
||||
$i=0;
|
||||
$datum_sec = $datum_obj->mktime_datum($datum);
|
||||
foreach ($ort->result as $row)
|
||||
{
|
||||
$i++;
|
||||
echo '<tr class="liste'.($i%2).'">';
|
||||
echo "<td>$row->ort_kurzbz</td>";
|
||||
echo "<td>$row->bezeichnung</td>";
|
||||
echo "<td>$row->planbezeichnung</td>";
|
||||
echo "<td>$row->max_person</td>";
|
||||
echo "<td><a href='stpl_week.php?type=ort&ort_kurzbz=$row->ort_kurzbz&datum=".$datum_sec."' class='Item'>Reservieren</a></td>";
|
||||
echo '</tr>';
|
||||
}
|
||||
echo '</table>';
|
||||
}
|
||||
?>
|
||||
@@ -274,6 +274,8 @@ function FunktionDetailSpeichern()
|
||||
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
|
||||
FunktionenSelectID=val.dbdml_data;
|
||||
FunktionenTreeDatasource.Refresh(false);
|
||||
document.getElementById('funktion-checkbox-neu').checked=false;
|
||||
document.getElementById('funktion-textbox-benutzerfunktion_id').value=FunktionenSelectID;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -101,6 +101,8 @@ if($prestudent_id!='')
|
||||
<menuitem value="Interessent" label="Interessent"/>
|
||||
<menuitem value="Bewerber" label="Bewerber"/>
|
||||
<menuitem value="Student" label="Student"/>
|
||||
<menuitem value="Unterbrecher" label="Unterbrecher"/>
|
||||
<menuitem value="Diplomand" label="Diplomand"/>
|
||||
</menupopup>
|
||||
</menulist>
|
||||
</row>
|
||||
|
||||
+93
-1
@@ -29,7 +29,7 @@ class ort
|
||||
var $conn; // @var resource DB-Handle
|
||||
var $new; // @var boolean
|
||||
var $errormsg; // @var string
|
||||
var $result = array(); // @var fachbereich Objekt
|
||||
var $result = array(); // @var ort Objekt
|
||||
|
||||
//Tabellenspalten
|
||||
var $ort_kurzbz; // @var string
|
||||
@@ -292,5 +292,97 @@ class ort
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
// ****
|
||||
// * Sucht nach freien Raeumen
|
||||
// * @param datum ... Datum fuer das der Raum gesucht wird
|
||||
// * zeit_von ... Zeit ab wann soll der Raum frei sein
|
||||
// * zeit_bis ... Zeit bis wann soll der Raum frei sein
|
||||
// * raumtyp ... Art des Raumes (optional)
|
||||
// * anzpersonen ... Anzahl der Personen die mindestens Platz haben sollen (optional)
|
||||
// * reservierung ... true wenn nur Raeume aufscheinen sollen die auch Reservierbar sind
|
||||
// * db_table ... Stundenplantabelle die geprueft werden soll
|
||||
// * @return true wenn ok, false im Fehlerfall
|
||||
// ****
|
||||
function search($datum, $zeit_von, $zeit_bis, $raumtyp=null, $anzpersonen=null, $reservierung=true, $db_table='stundenplandev')
|
||||
{
|
||||
$stundevon = 1;
|
||||
$stundebis = 1;
|
||||
|
||||
//stundevon ermitteln
|
||||
$qry = "SELECT stunde FROM (
|
||||
SELECT stunde, extract(epoch from (beginn-('$zeit_von'::time))) AS delta FROM lehre.tbl_stunde
|
||||
UNION
|
||||
SELECT stunde, extract(epoch from (ende-('$zeit_von'::time))) AS delta FROM lehre.tbl_stunde
|
||||
) foo WHERE delta>=0 ORDER BY delta LIMIT 1;";
|
||||
|
||||
if($result = pg_query($this->conn, $qry))
|
||||
if($row = pg_fetch_object($result))
|
||||
$stundevon = $row->stunde;
|
||||
|
||||
//stundebis ermitteln
|
||||
$qry = "SELECT stunde FROM (
|
||||
SELECT stunde, extract(epoch from (beginn-('$zeit_bis'::time))) AS delta FROM lehre.tbl_stunde
|
||||
UNION
|
||||
SELECT stunde, extract(epoch from (ende-('$zeit_bis'::time))) AS delta FROM lehre.tbl_stunde
|
||||
) foo WHERE delta>=0 ORDER BY delta LIMIT 1;";
|
||||
|
||||
if($result = pg_query($this->conn, $qry))
|
||||
if($row = pg_fetch_object($result))
|
||||
$stundebis = $row->stunde;
|
||||
|
||||
//Freie Raeume suchen
|
||||
$qry = "SELECT
|
||||
DISTINCT tbl_ort.*
|
||||
FROM
|
||||
public.tbl_ort JOIN public.tbl_ortraumtyp USING(ort_kurzbz)
|
||||
WHERE
|
||||
aktiv AND ort_kurzbz NOT LIKE '\\\\_%'";
|
||||
if($reservierung)
|
||||
$qry.=" AND reservieren";
|
||||
if($raumtyp!=null)
|
||||
$qry.=" AND raumtyp_kurzbz='$raumtyp'";
|
||||
if($anzpersonen!=null)
|
||||
$qry.=" AND (max_person>='$anzpersonen' OR max_person is null)";
|
||||
|
||||
$qry.=" AND ort_kurzbz NOT IN
|
||||
(
|
||||
SELECT ort_kurzbz FROM lehre.tbl_$db_table WHERE datum='$datum' AND stunde>='$stundevon' AND stunde<='$stundebis'
|
||||
UNION
|
||||
SELECT ort_kurzbz FROM campus.tbl_reservierung WHERE datum='$datum' AND stunde>='$stundevon' AND stunde<='$stundebis'
|
||||
)
|
||||
";
|
||||
|
||||
if($result = pg_query($this->conn, $qry))
|
||||
{
|
||||
while($row = pg_fetch_object($result))
|
||||
{
|
||||
$ort_obj = new ort($this->conn);
|
||||
|
||||
$ort_obj->ort_kurzbz = $row->ort_kurzbz;
|
||||
$ort_obj->bezeichnung = $row->bezeichnung;
|
||||
$ort_obj->planbezeichnung = $row->planbezeichnung;
|
||||
$ort_obj->max_person = $row->max_person;
|
||||
$ort_obj->aktiv = ($row->aktiv=='t'?true:false);
|
||||
$ort_obj->lehre = ($row->lehre=='t'?true:false);
|
||||
$ort_obj->lageplan = $row->lageplan;
|
||||
$ort_obj->dislozierung = $row->dislozierung;
|
||||
$ort_obj->kosten = $row->kosten;
|
||||
$ort_obj->reservieren = ($row->reservieren=='t'?true:false);
|
||||
$ort_obj->ausstattung = $row->ausstattung;
|
||||
$ort_obj->stockwerk = $row->stockwerk;
|
||||
$ort_obj->standort_kurzbz = $row->standort_kurzbz;
|
||||
$ort_obj->telefonklappe = $row->telefonklappe;
|
||||
|
||||
$this->result[] = $ort_obj;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$this->errormsg = 'Fehler beim Ermitteln eines Raumes';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
||||
@@ -253,7 +253,7 @@ class person
|
||||
{
|
||||
if($row->person_id!=$this->person_id)
|
||||
{
|
||||
$this->errormsg = 'Es existiert bereits eine Person mit dieser SVNR';
|
||||
$this->errormsg = 'Es existiert bereits eine Person mit dieser SVNR! Daten wurden NICHT gepeichert.';
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user