App/pgs/30_einsaetze/page.php

271 lines
12 KiB
PHP

<?php #pgs/xx_termine/class.php
class EinsätzePage extends BasePage
{
private $monthsback = 1;
protected function update($id) {
$this->get($id);
$qry = "UPDATE Einsätze SET Beginn = ?, Ende = ?, Thema = ?, Ort = ?, Dienstplan = ?, "
."Kategorie = ?, Platzvergabe = ?, Ausgelost = ?, Gruppe = ? WHERE ID = ?";
if ($stmt = $this->db->prepare($qry)) {
$Beginn = $this->man->input["ALARMIERUNGSZEIT"] ?? $this->output["MAIN"]["ALARMIERUNGSZEIT"];
$Ende = $this->man->input["EINSATZENDE"] ?? $this->output["MAIN"]["EINSATZENDE"];
$Thema = $this->man->input["THEMA"] ?? $this->output["MAIN"]["THEMA"];
$Ort = $this->man->input["ORT"] ?? $this->output["MAIN"]["ORT"];
$Dienstplan = $this->man->input["DIENSTPLAN"] ?? $this->output["MAIN"]["DIENSTPLAN"]["ID"];
$Kategorie = $this->man->input["KATEGORIE"] ?? $this->output["MAIN"]["KATEGORIE"]["ID"];
$Platzvergabe = array_key_exists("PLATZVERGABE", $this->man->input)
? $this->man->input["PLATZVERGABE"]
: (is_null($this->output["MAIN"]["PLATZVERGABE"]) ? null : $this->output["MAIN"]["PLATZVERGABE"]["ID"]);
$Ausgelost = $this->man->input["AUSGELOST"] ?? $this->output["MAIN"]["AUSGELOST"];
$Gruppe = array_key_exists("GRUPPE", $this->man->input)
? $this->man->input["GRUPPE"]
: (is_null($this->output["MAIN"]["GRUPPE"]) ? null : $this->output["MAIN"]["GRUPPE"]["ID"]);
$stmt->bind_param(
"ssssiiiiii",
$Beginn,
$Ende,
$Thema,
$Ort,
$Dienstplan,
$Kategorie,
$Platzvergabe,
$Ausgelost,
$Gruppe,
$id
);
if ($stmt->execute()) {
$this->man->AddMessage("Einsatz wurde aktualisiert!");
$this->get($id);
return 200;
} else {
$this->man->AddMessage("Mysql error: ".$this->db->error);
}
} else {
$this->man->AddMessage("Mysql error: ".$this->db->error);
}
return 500;
}
protected function insert() {
$qry = "INSERT INTO Einsätze (Beginn, Ende, Thema, Ort, Dienstplan, Kategorie, Platzvergabe, Gruppe) VALUES (?,?,?,?,?,?,?,?)";
if ($stmt = $this->db->prepare($qry)) {
$Beginn = $this->man->input["ALARMIERUNGSZEIT"] ?? "";
$Ende = $this->man->input["EINSATZENDE"] ?? "";
$Thema = $this->man->input["THEMA"] ?? "";
$Ort = $this->man->input["ORT"] ??"";
$Dienstplan = $this->man->input["DIENSTPLAN"] ?? null;
$Kategorie = $this->man->input["KATEGORIE"] ?? null;
$Platzvergabe = array_key_exists("PLATZVERGABE", $this->man->input)
? $this->man->input["PLATZVERGABE"]
: null;
$Gruppe = array_key_exists("GRUPPE", $this->man->input)
? $this->man->input["GRUPPE"]
: null;
$stmt->bind_param(
"ssssiiii",
$Beginn,
$Ende,
$Thema,
$Ort,
$Dienstplan,
$Kategorie,
$Platzvergabe,
$Gruppe
);
$stmt->execute();
if ($stmt->affected_rows==1) {
$this->man->AddMessage("Einsatz wurde hinzugefügt!");
$this->get($this->db->insert_id);
return 201;
} else {
$this->man->AddMessage("Einsatz konnte nicht hinzugefügt werden! ("
.$Beginn." / ".$Ende." / ".$Thema." / ".$Ort." / "
.$Dienstplan." / ".$Kategorie." / ".$Platzvergabe." / ".$Gruppe.")"
);
return 400;
}
} else {
$this->man->AddMessage("Mysql error: ".$this->db->error);
return 500;
}
}
protected function get($id = null) {
$this->output = [];
$where = "";
if ($id) {
$where = "WHERE e.ID = ? ";
} else if (sizeof($this->man->Filter())>0) {
$where = "WHERE 1 ";
foreach ($this->man->Filter() as $filter) {
$where.= "or"==$filter["and"] ? "OR " : "AND ";
if ("none"==$filter["field"]) {
$where.= "1 ";
} else {
switch ($filter["field"]) {
case "ALARMIERUNGSZEIT":
$where.= $this->getFilterString($filter["op"], ["<=", ">="], "t", "Beginn", $filter["value"]);
break;
case "EINSATZENDE":
$where.= $this->getFilterString($filter["op"], ["<=", ">="], "t", "Ende", $filter["value"]);
break;
case "THEMA":
$where.= $this->getFilterString($filter["op"], ["like", "not like"], "t", "Thema", $filter["value"]);
break;
case "DIENSTPLAN":
$where.= $this->getFilterString($filter["op"], ["=", "<>"], "t", "Dienstplan", $filter["value"]);
break;
case "KATEGORIE":
$where.= $this->getFilterString($filter["op"], ["=", "<>"], "t", "Kategorie", $filter["value"]);
break;
case "GRUPPE":
$where.= $this->getFilterString($filter["op"], ["=", "<>"], "t", "Gruppe", $filter["value"]);
break;
default:
$where.= "1 ";
} } }
} else {
/*$datefrom = date("Y-m-d H:i:s");
$this->man->filter[] = ["and" => "and", "field" => "EINSATZENDE", "op" => ">=", "value" => $datefrom];
$where = "WHERE ".$this->getFilterString(">=", [">="], "t", "Ende", $datefrom);*/
}
$qry = "SELECT e.ID, e.Alarmierungszeit, e.Einsatzende, e.Adresse, e.Art, e.Zusammenfassung, e.Einsatzleiter, e.Überprüft "
.", ea.Kategorie, ea.Name eaName, ea.Stichworte "
.", ek.Name ekName, ek.Farbe "
."FROM Einsätze e "
."LEFT JOIN Einsätze_Arten ea ON ea.ID=e.Art "
."LEFT JOIN Einsätze_Kategorien ek ON ek.ID=ea.Kategorie "
.$where
."ORDER BY e.Alarmierungszeit DESC ";
if ($stmt = $this->db->prepare($qry)) {
$userID = $this->man->user->ID();
if ($id) {
$stmt->bind_param("i", $id);
} else {
//$stmt->bind_param("i", $userID, $userID);
}
$stmt->execute();
$res = $stmt->get_result();
while ($row = $res->fetch_assoc()) {
$beginn_time = date("H:i", strtotime($row["Alarmierungszeit"]));
$ende_time = date("H:i", strtotime($row["Einsatzende"]));
$beginn_date = date("D, d.m.Y", strtotime($row["Alarmierungszeit"]));
$ende_date = "0000-00-00 00:00:00"== $row["Einsatzende"] ?
"?" : (
"00:00"==$ende_time ? date("D, d.m.Y", strtotime($row["Einsatzende"]) - 1) : date("D, d.m.Y", strtotime($row["Einsatzende"]))
);
$entry = [
"ID" => $row["ID"],
"MAIN" => [
"ALARMIERUNGSZEIT" => $row["Alarmierungszeit"],
"ALARMIERUNGSZEIT.DATUM" => date("D, d.m.Y", strtotime($row["Alarmierungszeit"])),
"ALARMIERUNGSZEIT.DATE" => date("Y-m-d", strtotime($row["Alarmierungszeit"])),
"ALARMIERUNGSZEIT.ZEIT" => date("H:i", strtotime($row["Alarmierungszeit"])),
"ALARMIERUNGSZEIT.TIME" => date("H:i", strtotime($row["Alarmierungszeit"])),
"EINSATZENDE" => $row["Einsatzende"],
"EINSATZENDE.DATUM" => date("d.m.Y", strtotime($row["Einsatzende"])),
"EINSATZENDE.DATE" => date("Y-m-d", strtotime($row["Einsatzende"])),
"EINSATZENDE.ZEIT" => date("H:i", strtotime($row["Einsatzende"])),
"EINSATZENDE.TIME" => date("H:i", strtotime($row["Einsatzende"])),
"DATUM" => $beginn_date.($beginn_date!=$ende_date && "?"!=$ende_date ? " - ".$ende_date : ""),
"ZEIT" => $beginn_time." - ".("?"==$ende_date ? "?" : $ende_time),
"ADRESSE" => $row["Adresse"],
"ART" => [
"ID" => $row["Art"],
"KATEGORIE" => ["ID" => $row["Kategorie"], "NAME" => $row["ekName"], "FARBE" => $row["Farbe"]],
"NAME" => is_null($row["Art"]) ? "Unbekannt" : $row["eaName"],
"STICHWORTE" => $row["Stichworte"]
],
"ZUSAMMENFASSUNG" => $row["Zusammenfassung"],
"EINSATZLEITER" => $row["Einsatzleiter"],
"ÜBERPRÜFT" => $row["Überprüft"],
"ADMIN" => true,
],
"SUB" => [
/*"ANMELDUNG" => $registration,
"TEILNAHME" => $isPrivileged ? $teilnahme : []*/
],
];
$group = date("Y", strtotime($row["Alarmierungszeit"]));
$this->addEntryToOutput($group, $entry, $id);
}
} else {
$this->man->AddMessage("Mysql error: ".$this->db->error);
}
return 200;
}
protected function fillOptions($admin = false) {
$ret = array();
$res = $this->db->query("SELECT ID, Jahr, Name FROM Termine_Dienstpläne ORDER BY Jahr DESC, Name DESC");
while ($row = $res->fetch_assoc()) {
$ret["DIENSTPLAN"][] = ["ID" => $row["ID"], "JAHR" => $row["Jahr"], "NAME" => $row["Name"]];
}
$res = $this->db->query("SELECT ID, Name FROM Einsätze_Kategorien");
while ($row = $res->fetch_assoc()) {
$ret["KATEGORIE"][] = ["ID" => $row["ID"], "NAME" => $row["Name"]];
}
$res = $this->db->query("SELECT ID, Kürzel, Name FROM Struktur_Abteilungen");
while ($row = $res->fetch_assoc()) {
$ret["ABTEILUNG"][] = ["ID" => $row["ID"], "KÜRZEL" => $row["Kürzel"], "NAME" => $row["Name"]];
}
$ret["PLATZVERGABE"][] = ["ID" => "__NULL__", "NAME" => "Ohne"];
$res = $this->db->query("SELECT ID, Name FROM Termine_Platzvergaben ORDER BY Name ASC");
while ($row = $res->fetch_assoc()) {
$ret["PLATZVERGABE"][] = ["ID" => $row["ID"], "NAME" => $row["Name"]];
}
$ret["GRUPPE"][] = ["ID" => "__NULL__", "KÜRZEL" => "Ohne", "NAME" => "Ohne"];
$res = $this->db->query("SELECT ID, Kürzel, Name FROM Struktur_Gruppen ORDER BY Name ASC");
while ($row = $res->fetch_assoc()) {
$ret["GRUPPE"][] = ["ID" => $row["ID"], "KÜRZEL" => $row["Kürzel"], "NAME" => $row["Name"]];
}
if ($admin) {
$res = $this->db->query("SELECT p.ID, Nachnamen, Vornamen, pk.Name pkName FROM Personal p LEFT JOIN Personal_Kategorien pk ON pk.ID=p.Kategorie "
."ORDER BY pk.Reihenfolge ASC, Nachnamen ASC, Vornamen ASC");
$lastKategorie = "";
while ($row = $res->fetch_assoc()) {
if ($row["pkName"]!=$lastKategorie) {
$ret["TEILNAHME"][] = ["ID" => 0, "NAME" => " === ".$row["pkName"]." === "];
$lastKategorie = $row["pkName"];
}
$ret["TEILNAHME"][] = ["ID" => $row["ID"], "NAME" => preg_replace("/(?<![ -])\p{Ll}+/u", ".", $row["Vornamen"])." ".$row["Nachnamen"]];
} }
return $ret;
}
private function teilnahmeGetAll($terminID) {
$ret = [];
$qry = "SELECT p.ID, p.Nachnamen, p.Vornamen, GROUP_CONCAT(l.Kürzel SEPARATOR ', ') lehrgänge, tt.Status "
."FROM Einsätze_Teilnahmen tt "
."LEFT JOIN Personal p ON p.ID=tt.Personal "
."LEFT JOIN Personal_Lehrgänge pl ON pl.Personal=tt.Personal "
."LEFT JOIN Lehrgänge l ON l.ID=pl.Lehrgänge "
."WHERE tt.Einsätze = ? "
."GROUP BY p.ID ORDER BY tt.Status DESC, p.Kategorie DESC, p.Nachnamen ASC, p.Vornamen ASC, l.ID ASC";
if ($stmt = $this->db->prepare($qry)) {
$stmt->bind_param("i", $terminID);
$stmt->execute();
$res = $stmt->get_result();
while ($row = $res->fetch_assoc()) {
$status = $row["Status"]==2 ? "LEAD" : ($row["Status"]==1 ? "CAN" : "WANT");
$entry = [
"ID" => $row["ID"],
"NAME" => preg_replace("/(?<![ -])\p{Ll}+/u", ".", $row["Vornamen"])." ".$row["Nachnamen"],
"NACHNAMEN" => $row["Nachnamen"],
"VORNAMEN" => $row["Vornamen"],
"STATUS" => "__CASE__:".$status,
"LEHRGÄNGE" => $row["lehrgänge"] ?? "Keine",
];
$ret[] = $entry;
}
} else {
$this->man->AddMessage("Mysql error: ".$this->db->error);
}
return $ret;
} }