This commit is contained in:
Andreas Österreicher
2008-04-09 08:29:46 +00:00
parent cb904aa765
commit d6f10c8227
5 changed files with 197 additions and 2 deletions
+99
View File
@@ -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>&nbsp;<a class="Item" href="index.php">Lehrveranstaltungsplan</a> &gt;&gt; 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>';
}
?>
+2
View File
@@ -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
View File
@@ -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;
}
}
}
?>
+1 -1
View File
@@ -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;
}
}