<?php
/**
* @author Bettina Schwarzer, Fritz-Haber-Institut
* @copyright 06/2012
*
* Liste RaumArbeits-Gruppe Raeume, Mitarbeiter
*
*/
error_reporting(E_ALL ^ E_NOTICE);
session_start();
if (! isset($_SESSION["userid"]))
{
include_once ("inc/func_lib.inc.php");
login($_SERVER["PHP_SELF"]);
exit;
}
if (is_null($_SESSION["recht"]) || (!is_null($_SESSION["recht"]) && !in_array("asr",$_SESSION["recht"]) && !in_array("ase",$_SESSION["recht"])))
{
header("Location: start.php");
exit;
}
include_once($_SERVER['DOCUMENT_ROOT'] ."/fhiiqm/inc/dbconnect.inc.php");
if (!isset($dbc) || !$dbc) $dbc = new dbconnection();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-1" />
<link href="css/db.css" rel="STYLESHEET" type="TEXT/CSS" media="screen"/>
<link href="css/db_print.css" rel="STYLESHEET" type="TEXT/CSS" media="print"/>
<title>Raum-Arbeitsgruppen</title>
</head>
<body onload="document.ffilter.filter.focus();">
<?php
echo " ";
echo "<div class=\"float-br smaller\" valign='top'>";
echo " user: " . $_SESSION["userid"];
echo " <a class='sc' href='/fhiiqm/logout.php' title='Session beenden'>logout</a></div>\n";
echo "<div class=\"float-r\"><img src=\"img/role.png\" border=\"0\" alt=\"Liste Raum-Arbeits-Gruppe\" title=\"Liste Raum-Arbeits-Gruppe\"/></div>\n";
// Felder, nach denen gefiltert werden kann
$fields = array(2=>"Raum-Arbeits-Gruppe",3=>"Abteilung",4=>"Raum",5=>"Mitarbeiter",6=>"Gefahr-Maßnahmen",7=>"Vorsorge");
$gmv = $_GET['g']; // mit Gefahr, Massnahmen und Vorsorge
if (!$gmv || $_POST['ges']) $gmv = $_POST['g'];
$zeil = $_GET["z"];
if (!$zeil) $zeil = $_POST["z"];
if (!$zeil) $zeil = 25; // Anzahl der gezeigten Zeilen
$start = $_GET["st"];
if (!$start) $start=0;
$sort = $_GET["s"]; // Sortierung nach Spalte
if (!isset($sort) && !$sort) $sort = $_POST["s"];
$dir = $_GET["d"]; // Sortierrichtung
if (!isset($dir) && !$dir) $dir = $_POST["d"];
$fnum = $_GET["f"]; // Spaltennummer, nach der aktuell gefiltert wird
if (!isset($fnum) && !$fnum) $fnum = $_POST["f"];
$filter = $_POST["filter"];
if (!isset($filter) && !$filter) $filter = $_GET["b"];
$subf = $_POST["subf"]; // submit
if (!isset($fnum) || !$fnum) $fnum = 1;
if (!isset($filter) || !$filter) $filter = "";
if (!isset($sort) || !$sort) $sort = "3";
if (!isset($dir) || !$dir) $dir = "";
$getp = "&st=$start&z=$zeil&s=$sort&f=$fnum&b=$filter&g=$gmv"; //Link fuer Liste zurueck
include_once ($_SERVER['DOCUMENT_ROOT'] ."/fhiiqm/inc/func_lib.inc.php");
if ($gmv) $proc = "rag_ma_raum_gef_massn_vors"; else $proc = "raumarbgruppe_flist";
$sql = "CALL $proc($sort,'" . $dir . "',$fnum, '" . $filter . "',$start,$zeil,@anz);";
// liefert: rag_ID,rag_bez,abt_name,raeume,ma (,gefahr-massnahmen,vorsorge)
$result = $dbc ->queryObjectArray($sql);
if ($result)
{
$bg1 = "#F8F8F8";
$bg2 = "#DEDFE1";
$bg = "#FFFFFF";
echo "<div align='center'>\n";
echo "<p><b>Liste der Raum-Arbeits-Gruppen</b></p>\n";
echo "<table border='0' cellspacing='0'>\n";
echo "<tr><td class='bigger'>Mittels '<img src='/fhiiqm/img/auf.gif' border='0' width='11' hight='11' />' / '<img src='/fhiiqm/img/ab.gif' border='0' width='11' hight='11' />'
können Sie nach jeder Spalte auf- bzw. absteigend sortieren</td></tr>
<tr><td class='bigger'>'<img src='/fhiiqm/img/filter.gif' border='0' width='14' hight='11' />' ermöglicht das Filtern nach ausgewählten Spalten der Liste</td></tr>
<tr><td class='bigger'>Klick auf '<img src='/fhiiqm/img/edit.gif' border='0' width='11' hight='11'>' - Bearbeiten der Raum-Arbeits-Gruppe
</td></tr>\n";
echo "<tr><td>
<table><tr><td class='bigger'><i> anzeigen mit Gefährdungen, Maßnahmen, Vorsorge</i></td>";
echo "<td><form action=" . $_SERVER['PHP_SELF'] . " method='post' enctype='application/x-www-form-urlencoded' target='_self' id='toggle' name='toggle'>";
if ($gmv) $ck = "checked"; else $ck = "";
echo "<input type='checkbox' name='g' value='1' $ck /><input class=\"button\" type=\"submit\" value='»' name='ges' title='Gesamtliste'/>\n";
echo "</form></td></tr></table>
</td></tr>\n";
echo "</table>\n";
$ranz = $dbc -> querySingleItem("SELECT @anz");
printf ("<p>Es wurden %s Raum-Arbeits-Gruppen gefunden.</p>", $ranz);
if (isset($fnum) && $fnum>1 && !$filter && !$subf)
{
// Formular anzeigen fuer Filterbegriff
$text = $fields[$fnum];
$azeil = array(10=>'10',20=>'20',25=>'25',50=>'50',100=>'100',9999=>'alle'); // Anzahl gezeigter rows
echo "<form action=" . $_SERVER['PHP_SELF'] . " method='post' enctype='application/x-www-form-urlencoded' id='ffilter' name='ffilter' target='_self'>\n";
echo "<input type='hidden' name='s' value='$sort'>";
echo "<input type='hidden' name='d' value='$dir'>";
echo "<input type='hidden' name='f' value='$fnum'>";
echo "<input type='hidden' name='g' value='$gmv'>";
echo "<table width=\"40%\" border=\"0\">\n";
echo "<tr><td>filtern nach $text: </td>";
echo "<td><input id='filter' name='filter' type=\"text\" size=\"30\" maxlength=\"30\" value=\"$filter\"/></td>";
echo "<td>Zeilen/Seite? <select name='z'>\n";
foreach ($azeil as $key=>$val)
{
if ($key == $zeil) $select = "selected"; else $select = "";
echo "<option $select value='$key'>$val</option>\n";
}
echo "</select></td>\n";
echo "<td><input class=\"button\" type=\"submit\" value=\"finden\" name=\"subf\" title=\"subf\" /></td></tr></table>\n";
echo "</form>\n";
echo "<p> </p>\n";
}
if (isset($gmv) && $gmv) $width = " width='99%'"; else $width = "";
echo "<table$width>\n";
if ($filter>'!') echo "<tr><td class='bigger' colspan=5>Filter: ". $fields["$fnum"] . " wie '$filter'</td><tr>\n";
// Listenkopf generieren
echo "<tr bgcolor='#68ACBF'>";
tab_column(2,"Raum-Arb.-Gruppe.",$sort,$dir,2,$fnum,$filter,$start,$zeil,"",$gmv);
tab_column(3,"Abt.",$sort,$dir,3,$fnum,$filter,$start,$zeil,"",$gmv);
tab_column(4,"zugeord. Räume",$sort,$dir,4,$fnum,$filter,$start,$zeil,"",$gmv);
tab_column(5,"zugeord. Mitarb.",$sort,$dir,5,$fnum,$filter,$start,$zeil,"",$gmv);
if (isset($gmv) && $gmv)
{
tab_column(6,"Gefährdung: Maßnahmen",$sort,$dir,6,$fnum,$filter,$start,$zeil,"",$gmv);
tab_column(7,"Vorsorge",$sort,$dir,7,$fnum,$filter,$start,$zeil,"",$gmv);
tab_column(8,"Betriebsanweisung",$sort,$dir,0,$fnum,$filter,$start,$zeil,"",$gmv);
}
echo "<th> </th></tr>\n";
function doc_bez($val)
{ // Callback-Funktion fuer array_map
return substr($val,strpos($val,"_")+1);
}
foreach ($result as $row)
{
if ($bg == $bg1) $bg = $bg2; else $bg = $bg1;
if (strpos($row->rag_bez,"DynamiX")) $row->rag_bez = str_replace("X","χ",$row->rag_bez);
echo "<tr bgcolor='" . $bg . "'><td>$row->rag_bez</td>";
echo "<td>$row->abt_name</td>";
echo "<td>".str_replace(";","<br />",$row->raeume)."</td>";
echo "<td>".str_replace(";","<br />",$row->ma)."</td>";
if (isset($gmv) && $gmv)
{
echo "<td width='35%'>".str_replace(";","<br />",$row->gefahr_msn)."</td>";
if (strpos($row->vorsorge,";")===0) $row->vorsorge = substr($row->vorsorge,1);
echo "<td>".str_replace(";","<br />",$row->vorsorge)."</td>";
if ($row->doc > " ")
{
echo "<td>";
$docs = explode("; ",$row->doc); // ein Array-Element je doc
$docu = array_unique(array_map("doc_bez",$docs)); // array docs ohne 'id_' und ohne mehrfache values
// print_r ($docb); echo "<br />";
foreach ($docs as $key => $doc)
if (array_key_exists($key,$docu))
echo "<a href='/fhiiqm/infos/$doc'>".substr($doc,strpos($doc,"_")+1)."</a><br />";
echo "</td>";
}
else echo "<td> </td>";
}
echo "<td><a href='/fhiiqm/raumarbgr_ed.php?i=$row->rag_ID$getp'><img src=\"/fhiiqm/img/edit.gif\" alt='edit' title='edit' border='0'/></a></td></tr>\n";
}
echo "</table></div>\n";
echo "<br /> ";
// Sortierung und Filter aus $_GET fuer weitere Seiten
foreach ($_GET as $key=>$val)
{
if ($key != "st") $liste .= "&" . $key ."=".$val;
}
// Sortierung und Filter aus $_POST fuer weitere Seiten
if ($subf)
foreach ($_POST as $key=>$val)
{
if ($key != "st" && $key != "subf" && $key != "filter") $liste .= "&" . $key ."=".$val;
if ($key == "filter") $liste .= "&b=" . $val;
}
if (isset($gmv)&& $gmv) $liste .= "&g=1";
// Links auf andere Seiten generieren
liste_links($start,$zeil,$ranz,$liste);
}
else
{
if ($dbc -> error)
echo "error: " . $dbc -> error . "<br />\n";
else
{
echo "<p class='red'> Leider nichts gefunden für ". $fields["$fnum"] . " wie '$filter'!</p><br />";
echo " <a href=\"" . $_SERVER["PHP_SELF"] . "\" target=\"_self\" title=\"Raum-Arbeits-Gruppe-Liste\">Raum-Arbeits-Gruppe-Liste</a></p>\n";
}
}
$dbc -> close();
if (!is_null($_SESSION["recht"]) && in_array("re",$_SESSION["recht"]))
echo "<p> <a href=\"raumarbgr_ed.php\" target=\"_self\" title=\"Raum-Arbeits-Gruppe bearbeiten\" class=\"sc\">Weitere Raum-Arbeits-Gruppe bearbeiten</a></p>\n";
?>
</body>
</html>