Anpassung Ladezeit Impfen + Urlaubsplaner
This commit is contained in:
+62
-37
@@ -4,6 +4,7 @@ session_start();
|
||||
// WICHTIG: Pfade aus /admin heraus korrekt auflösen
|
||||
require_once __DIR__ . "/../inc/config.inc.php";
|
||||
require_once __DIR__ . "/../inc/functions.inc.php";
|
||||
require_once __DIR__ . "/../inc/company_holiday_sync.inc.php";
|
||||
|
||||
// Login prüfen
|
||||
$user = check_admin_user();
|
||||
@@ -624,12 +625,12 @@ if(!check_worker()){
|
||||
|
||||
echo "Start: <input class='form-control' name='Starttime[]' type='date' value='" . htmlspecialchars($start, ENT_QUOTES, 'UTF-8') . "'>
|
||||
Ende: <input class='form-control' name='Endetime[]' type='date' value='" . htmlspecialchars($ende, ENT_QUOTES, 'UTF-8') . "'><br>
|
||||
Vertretung: <input class='form-control' name='vertretung[]' type='text' value='" . htmlspecialchars($vertretung, ENT_QUOTES, 'UTF-8') . "'>";
|
||||
Vertretung: <input class='form-control' name='vertretung[]' type='text' required value='" . htmlspecialchars($vertretung, ENT_QUOTES, 'UTF-8') . "'>";
|
||||
|
||||
echo "<br>Vertretung Telefon: <input class='form-control' name='vertretertelefon[]' type='text' value='" . htmlspecialchars($vertretertelefon, ENT_QUOTES, 'UTF-8') . "'>
|
||||
<br>Vertretung Adresse: <input class='form-control' name='vertreteradresse[]' type='text' value='" . htmlspecialchars($vertreteradresse, ENT_QUOTES, 'UTF-8') . "'>";
|
||||
echo "<br>Vertretung Telefon: <input class='form-control' name='vertretertelefon[]' type='text' required value='" . htmlspecialchars($vertretertelefon, ENT_QUOTES, 'UTF-8') . "'>
|
||||
<br>Vertretung Adresse: <input class='form-control' name='vertreteradresse[]' type='text' required value='" . htmlspecialchars($vertreteradresse, ENT_QUOTES, 'UTF-8') . "'>";
|
||||
|
||||
echo "<br>Vertretung Webseite: <input class='form-control' name='vertreterurl[]' type='text' value='" . htmlspecialchars($vertreterurl, ENT_QUOTES, 'UTF-8') . "'>";
|
||||
echo "<br>Vertretung Webseite: <input class='form-control' name='vertreterurl[]' type='text' required value='" . htmlspecialchars($vertreterurl, ENT_QUOTES, 'UTF-8') . "'>";
|
||||
|
||||
echo "<input name='urlaubid[]' type='hidden' value='" . $urlaubid . "'><br>";
|
||||
}
|
||||
@@ -656,40 +657,64 @@ if(!check_worker()){
|
||||
}else if (($_POST["aktion"] ?? '') == "5") {
|
||||
// Termine in DB speichern.
|
||||
$i =0;
|
||||
foreach ($_POST['Starttime'] as $Starttime) {
|
||||
//echo $datum . "<br>";
|
||||
if($_POST["Starttime"][$i] != "0000-00-00"){
|
||||
//echo $_POST["urlaubid"][$i] . "<br>";
|
||||
$stmt = $pdo->prepare("
|
||||
INSERT INTO urlaub
|
||||
(urlaubid, vertretung, start, ende, vertretertelefon, vertreteradresse, vertreterurl)
|
||||
VALUES
|
||||
(:urlaubid, :vertretung, :start, :ende, :telefon, :adresse, :url)
|
||||
ON DUPLICATE KEY UPDATE
|
||||
vertretung = VALUES(vertretung),
|
||||
start = VALUES(start),
|
||||
ende = VALUES(ende),
|
||||
vertretertelefon = VALUES(vertretertelefon),
|
||||
vertreteradresse = VALUES(vertreteradresse),
|
||||
vertreterurl = VALUES(vertreterurl)
|
||||
");
|
||||
$pdo->beginTransaction();
|
||||
try {
|
||||
foreach ($_POST['Starttime'] as $Starttime) {
|
||||
if($_POST["Starttime"][$i] != "0000-00-00"){
|
||||
$vertretung = trim((string)($_POST['vertretung'][$i] ?? ''));
|
||||
$vertretertelefon = trim((string)($_POST['vertretertelefon'][$i] ?? ''));
|
||||
$vertreteradresse = trim((string)($_POST['vertreteradresse'][$i] ?? ''));
|
||||
$vertreterurl = trim((string)($_POST['vertreterurl'][$i] ?? ''));
|
||||
|
||||
$ok = $stmt->execute([
|
||||
':urlaubid' => (int)$_POST['urlaubid'][$i], // 0 = INSERT, >0 = UPDATE
|
||||
':vertretung' => $_POST['vertretung'][$i],
|
||||
':start' => $_POST['Starttime'][$i],
|
||||
':ende' => $_POST['Endetime'][$i],
|
||||
':telefon' => $_POST['vertretertelefon'][$i],
|
||||
':adresse' => $_POST['vertreteradresse'][$i],
|
||||
':url' => $_POST['vertreterurl'][$i],
|
||||
]);
|
||||
if ($vertretung === '' || $vertretertelefon === '' || $vertreteradresse === '' || $vertreterurl === '') {
|
||||
throw new RuntimeException("Bitte alle Vertreterinformationen fuer jeden Urlaubseintrag vollstaendig ausfuellen.");
|
||||
}
|
||||
|
||||
if (!$ok) {
|
||||
throw new RuntimeException("Fehler beim Eintragen in der Datenbank.");
|
||||
$stmt = $pdo->prepare("
|
||||
INSERT INTO urlaub
|
||||
(urlaubid, vertretung, start, ende, vertretertelefon, vertreteradresse, vertreterurl)
|
||||
VALUES
|
||||
(:urlaubid, :vertretung, :start, :ende, :telefon, :adresse, :url)
|
||||
ON DUPLICATE KEY UPDATE
|
||||
vertretung = VALUES(vertretung),
|
||||
start = VALUES(start),
|
||||
ende = VALUES(ende),
|
||||
vertretertelefon = VALUES(vertretertelefon),
|
||||
vertreteradresse = VALUES(vertreteradresse),
|
||||
vertreterurl = VALUES(vertreterurl)
|
||||
");
|
||||
|
||||
$ok = $stmt->execute([
|
||||
':urlaubid' => (int)$_POST['urlaubid'][$i], // 0 = INSERT, >0 = UPDATE
|
||||
':vertretung' => $vertretung,
|
||||
':start' => $_POST['Starttime'][$i],
|
||||
':ende' => $_POST['Endetime'][$i],
|
||||
':telefon' => $vertretertelefon,
|
||||
':adresse' => $vertreteradresse,
|
||||
':url' => $vertreterurl,
|
||||
]);
|
||||
|
||||
if (!$ok) {
|
||||
throw new RuntimeException("Fehler beim Eintragen in der Datenbank.");
|
||||
}
|
||||
|
||||
$urlaubId = (int)$_POST['urlaubid'][$i];
|
||||
if ($urlaubId <= 0) {
|
||||
$urlaubId = (int)$pdo->lastInsertId();
|
||||
}
|
||||
if ($urlaubId > 0) {
|
||||
vacationSyncCompanyHolidayFromUrlaub($pdo, $urlaubId, $internUserId);
|
||||
}
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
$pdo->commit();
|
||||
} catch (Throwable $e) {
|
||||
if ($pdo->inTransaction()) {
|
||||
$pdo->rollBack();
|
||||
}
|
||||
throw $e;
|
||||
}
|
||||
echo "Einträge wurden in der Datenbank gespeichert!<br><br>";
|
||||
|
||||
}else if (($_POST["aktion"] ?? '') == "6") {
|
||||
@@ -2023,10 +2048,10 @@ if(!check_worker()){
|
||||
<script type="text/javascript">
|
||||
|
||||
function AddneueTermine(){
|
||||
|
||||
|
||||
var div = document.getElementById('neuerUrlaub');
|
||||
|
||||
div.innerHTML += "Start: <input name=Starttime[] type=date class='form-control' > Ende: <input name=Endetime[] type=date class='form-control' >Vertretung: <input type=text name=vertretung[] weight=100 class='form-control'> Vertretung Telefon: <input type=text name=vertretertelefon[] weight=100 class='form-control'> Vertretung Adresse: <input type=text name=vertreteradresse[] weight=100 class='form-control'> Vertretung Webseite: <input type=text name=vertreterurl[] weight=100 class='form-control'> <input name=urlaubid[] type=hidden value='0'> <br>";
|
||||
|
||||
div.innerHTML += "Start: <input name=Starttime[] type=date class='form-control' > Ende: <input name=Endetime[] type=date class='form-control' >Vertretung: <input type=text name=vertretung[] weight=100 class='form-control' required> Vertretung Telefon: <input type=text name=vertretertelefon[] weight=100 class='form-control' required> Vertretung Adresse: <input type=text name=vertreteradresse[] weight=100 class='form-control' required> Vertretung Webseite: <input type=text name=vertreterurl[] weight=100 class='form-control' required> <input name=urlaubid[] type=hidden value='0'> <br>";
|
||||
//Public: <select name=aktiv[] id='aktiv' required ><option value='1' >Ja</option> <option value='0'>Nein</option></select>
|
||||
|
||||
//document.getElementById('neueTermine').innerHTML = div;
|
||||
|
||||
Reference in New Issue
Block a user