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("/(?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("/(? $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; } }