diff --git a/cis/private/lvplan/raumsuche.php b/cis/private/lvplan/raumsuche.php new file mode 100644 index 000000000..172cc5fde --- /dev/null +++ b/cis/private/lvplan/raumsuche.php @@ -0,0 +1,99 @@ +, + * Andreas Oesterreicher and + * Rudolf Hangl . + */ +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 ' + + + + Reservierungsliste + + + +

+ + + + +
 Lehrveranstaltungsplan >> Raumsuche
+

+'; + +echo '
+ Datum* + Von* + Bis* + Raumtyp: + Anzahl Personen + +
'; +if($sent) +{ + $ort = new ort($conn); + $ort->search($datum, $vonzeit, $biszeit, $raumtyp, $anzahlpersonen, true); + + echo '
'; + echo ''; + $i=0; + $datum_sec = $datum_obj->mktime_datum($datum); + foreach ($ort->result as $row) + { + $i++; + echo ''; + echo ""; + echo ""; + echo ""; + echo ""; + echo ""; + echo ''; + } + echo '
RaumBezeichnungNummerPersonenReservieren
$row->ort_kurzbz$row->bezeichnung$row->planbezeichnung$row->max_personReservieren
'; +} +?> \ No newline at end of file diff --git a/content/funktionen.js.php b/content/funktionen.js.php index 4c3fdfb0a..50c1e013a 100644 --- a/content/funktionen.js.php +++ b/content/funktionen.js.php @@ -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; } } diff --git a/content/student/studentrolledialog.xul.php b/content/student/studentrolledialog.xul.php index cb17374d7..298de75e4 100644 --- a/content/student/studentrolledialog.xul.php +++ b/content/student/studentrolledialog.xul.php @@ -101,6 +101,8 @@ if($prestudent_id!='') + + diff --git a/include/ort.class.php b/include/ort.class.php index f4426063a..68e9f06a3 100644 --- a/include/ort.class.php +++ b/include/ort.class.php @@ -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; + } + } } ?> \ No newline at end of file diff --git a/include/person.class.php b/include/person.class.php index 533f510a4..74a315461 100644 --- a/include/person.class.php +++ b/include/person.class.php @@ -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; } }