fehler_zurueck('kriterien_eingetragen', 'startseite'); } break; } else { //Gewichtung zu den Kriterien muss angegeben werden. fehler_zurueck('gewichtung_angeben', 'startseite'); break; } case 'check_datum': if ($_POST['v'] != '') { $date = datum_pruefen($_POST['v']); if (!$date) { echo json_encode(fehler_behandlung('datum_fehler', true)); break; } $date_array = kalenderwoche($date); $sql = execute_query($connect, 'SELECT k.kriterium, k.id_kriterium, k.gewicht ' . 'FROM kriterien AS k, zeitraum AS z, auswahl_kriterien AS ak ' . 'WHERE z.von=\'' . pg_escape_string($connect, $date_array['von']) . '\'' . ' AND z.bis=\'' . pg_escape_string($connect, $date_array['bis']) . '\'' . ' AND z.id_zeitraum=ak.id_zeitraum' . ' AND k.id_kriterium=ak.id_kriterium'); if (pg_num_rows($sql) >= 1) { $result_sql = pg_fetch_all($sql); foreach ($result_sql as $utf_8) { foreach ($utf_8 as $key => $value) { $utf_8[$key] = utf8_encode($value); } $result_encode_sql[] = ['kriterium' => $utf_8['kriterium'], 'gewicht' => $utf_8['gewicht'], 'id_kriterium' => $utf_8['id_kriterium']]; } } else { $result_encode_sql[] = ['kriterium' => '', 'gewicht' => '']; } } else { $result_encode_sql[] = ['kriterium' => 'Bitte geben Sie ein Datum ein.', 'gewicht' => 'Nicht vorhanden']; }
/** * * Zeichnet den Chart für alle Phasen eines übergebenen Projektes */ function getProjektGantt() { global $projekt_kurzbz; global $studienjahr; global $ansicht; $projektphasen = new projektphase(); if (!$projektphasen->getProjektphasen($projekt_kurzbz)) { die('Kein gültiges Projekt übergeben.'); } $projekt = new projekt(); if (!$projekt->load($projekt_kurzbz)) { die('Konnte Projekt nicht laden.'); } $datum = new datum(); $widthPerWeek = 16; $startX = 20; $startY = 90; // KW in der 28.12 liegt ist letzte KW $datum_gesamt = $studienjahr . '-12-28'; $timestamp_gesamt = $datum->mktime_fromdate($datum_gesamt); $kw_gesamt = date('W', $timestamp_gesamt); // kommt auf Anzahl der Phasen an $height = count($projektphasen->result) * 50; // Zeichne Kalenderjahr -> beginnend mit KW 1 if ($ansicht == 'kalenderjahr') { echo '<?xml version="1.0" encoding="UTF-8" standalone="no"?> <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 20010904//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">'; echo '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="100%" height="100%" viewBox="0 0 750 700"> <rect x="' . $startX . '" y="' . $startY . '" width="' . $kw_gesamt * $widthPerWeek . '" height="' . $height . '" style="color:#000000;fill:none;stroke:#e1e1e1;stroke-width:1;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />'; // Überschriften echo '<text x="25%" y="40" style="font-size:33px">Phasen Kalenderjahr: ' . $studienjahr . '</text>'; echo '<text x="' . ($startX - 10) . '" y="' . ($startY - 5) . '" style="font-size:13px" text-anchor="end"> KW:</text>'; // Zeichne Raster for ($i = 1; $i <= $kw_gesamt; $i++) { $x1 = $startX + $i * $widthPerWeek; echo '<line x1="' . $x1 . '" y1="' . $startY . '" x2="' . $x1 . '" y2="' . ($height + $startY) . '" style="stroke:#e1e1e1; stroke-width:2px;" />'; if ($i % 2 == 1) { echo '<text x="' . ($x1 - $widthPerWeek) . '" y="' . ($startY - 5) . '" style="font-size:13px">' . $i . '</text>'; } } // aktuelle KW markieren $timestamp_now = time(); $kw_now = kalenderwoche($timestamp_now); $year_now = date("Y", $timestamp_now); if ($year_now == $studienjahr) { $x = $startX + $kw_now * $widthPerWeek - $widthPerWeek / 2; echo '<line x1="' . $x . '" y1="' . ($startY - 20) . '" x2="' . $x . '" y2="' . ($height + $startY + 20) . '" style="stroke:red; stroke-width:4px;" />'; } $i = 0; foreach ($projektphasen->result as $phase) { $width = 0; $x = 0; // wenn kein start oder ende angegeben -> nichts zeichnen -> width=0 if ($phase->start != '' && $phase->ende != '') { $timestamp_beginn = $datum->mktime_fromdate($phase->start); $timestamp_end = $datum->mktime_fromdate($phase->ende); $kw_beginn = kalenderwoche($timestamp_beginn); $kw_end = kalenderwoche($timestamp_end); // kw soll bei 0 zu zeichnen beginnen $kw_beginn = $kw_beginn - 1; $kw_end = $kw_end - 1; $year_beginn = date("Y", $timestamp_beginn); $year_end = date("Y", $timestamp_end); // phase beginnt und endet im Jahr if ($year_end == $year_beginn && $year_beginn == $studienjahr) { $width = ($kw_end - $kw_beginn + 1) * $widthPerWeek; $x = $startX + $kw_beginn * $widthPerWeek; } else { if ($year_beginn == $studienjahr && $year_end > $year_beginn) { $width = ($kw_gesamt - $kw_beginn) * $widthPerWeek; $x = $startX + $kw_beginn * $widthPerWeek; } else { if ($year_beginn < $studienjahr && $year_end > $studienjahr) { $width = $kw_gesamt * $widthPerWeek; $x = $startX; } else { if ($year_beginn < $studienjahr && $year_end == $studienjahr) { $width = ($kw_end + 1) * $widthPerWeek; $x = $startX; } } } } } $style = ''; $pr_phase = new projektphase(); $ende_phase = $phase->ende; $date_now = date('Y-m-d', time()); // check ob phase in vergangenheit liegt und noch nicht abgeschlossen ist -> markieren if (!$pr_phase->isPhaseErledigt($phase->projektphase_id) && $date_now > $ende_phase) { $style = 'style ="stroke:pink;stroke-width:10;"'; } // zeichne balken echo '<rect x="' . $x . '" y="' . ($startY + 10 + $i * 50) . '" width ="' . $width . '" height ="30" fill="' . $phase->farbe . '" stroke="black" ' . $style . '/>'; echo '<text x="' . ($startX - 10) . '" y="' . ($startY + 30 + $i * 50) . '" style="font-size:15px" text-anchor="end">' . htmlspecialchars($phase->bezeichnung) . '</text>'; $i++; } echo '<text x="10%" y="' . (($i + 1) * 50 + $startY) . '" style="font-size:16px">Projekt: ' . htmlspecialchars($projekt->titel) . '</text>'; echo '</svg>'; } else { if ($ansicht == 'studienjahr') { echo '<?xml version="1.0" encoding="UTF-8" standalone="no"?> <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 20010904//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">'; echo '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="100%" height="100%" viewBox="0 0 750 800">'; // Überschriften echo '<text x="25%" y="40" style="font-size:33px">Phasen Studienjahr: ' . $studienjahr . '/' . ($studienjahr + 1) . '</text>'; echo '<text x="' . ($startX - 10) . '" y="' . ($startY - 5) . '" style="font-size:13px" text-anchor="end"> KW:</text>'; // WS $year_old = $studienjahr . '-09-01'; $timestamp_old = $datum->mktime_fromdate($year_old); $kw_old = kalenderwoche($timestamp_old); // SS $year_new = $studienjahr + 1 . '-09-01'; $timestamp_new = $datum->mktime_fromdate($year_new); $kw_new = kalenderwoche($timestamp_new); // gesamtanzahl der KWs im Studienjahr $y = 0; // Zeichne Raster studienjahr WS for ($i = $kw_old; $i <= $kw_gesamt; $i++) { $x1 = $startX + $y * $widthPerWeek; echo '<line x1="' . $x1 . '" y1="' . $startY . '" x2="' . $x1 . '" y2="' . ($height + $startY) . '" style="stroke:#e1e1e1; stroke-width:2px;" />'; if ($y % 2 == 0) { echo '<text x="' . $x1 . '" y="' . ($startY - 5) . '" style="font-size:13px">' . $i . '</text>'; } $y++; } // Zeichne Raster studienjahr SS for ($i = 1; $i <= $kw_new; $i++) { $x1 = $startX + $y * $widthPerWeek; echo '<line x1="' . $x1 . '" y1="' . $startY . '" x2="' . $x1 . '" y2="' . ($height + $startY) . '" style="stroke:#e1e1e1; stroke-width:2px;" />'; if ($y % 2 == 0) { echo '<text x="' . $x1 . '" y="' . ($startY - 5) . '" style="font-size:13px">' . $i . '</text>'; } $y++; } echo '<rect x="' . $startX . '" y="' . $startY . '" width="' . $y * $widthPerWeek . '" height="' . $height . '" style="color:#000000;fill:none;stroke:#e1e1e1;stroke-width:1;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" />'; $i = 0; foreach ($projektphasen->result as $phase) { $width = 0; $x = 0; // wenn kein start oder ende angegeben -> nichts zeichnen -> width=0 if ($phase->start != '' && $phase->ende != '') { $timestamp_beginn = $datum->mktime_fromdate($phase->start); $timestamp_end = $datum->mktime_fromdate($phase->ende); $kw_beginn = kalenderwoche($timestamp_beginn); $kw_end = kalenderwoche($timestamp_end); $kw_beginn = $kw_beginn; $kw_end = $kw_end; $startSS = $kw_gesamt - $kw_old; $year_beginn = date("Y", $timestamp_beginn); $year_end = date("Y", $timestamp_end); $test = 0; // phase beginnt und endet im WS if ($year_end == $year_beginn && $year_beginn == $studienjahr && $kw_beginn >= $kw_old) { $width = ($kw_end - $kw_beginn + 1) * $widthPerWeek; $x = $startX + ($kw_beginn - $kw_old) * $widthPerWeek; $test = 1; } // phase beginnt und endet im SS if ($year_end == $year_beginn && $year_beginn == $studienjahr + 1 && $kw_beginn >= 1 && $kw_end <= $kw_new) { if ($kw_end == 1) { // es kann auch sein dass 31.12 des kalenderjahres schon in der 1. KW liegt $kw_end = $kw_new; } $width = ($kw_end - $kw_beginn + 1) * $widthPerWeek; $x = $startX + ($kw_beginn + $startSS) * $widthPerWeek; $test = 2; } else { if ($year_beginn == $studienjahr && $year_end == $studienjahr + 1 && $kw_beginn >= $kw_old && $kw_end <= $kw_new) { $width = ($kw_gesamt - $kw_beginn + $kw_end + 1) * $widthPerWeek; $x = $startX + ($kw_beginn - $kw_old) * $widthPerWeek; $test = 3; } else { if ($year_beginn == $studienjahr && $kw_beginn <= $kw_old && ($year_end == $studienjahr + 1 && $kw_end >= $kw_new || $year_end > $studienjahr + 1)) { $width = $y * $widthPerWeek; $x = $startX; $test = 4; } else { if ($year_beginn < $studienjahr && $year_end > $studienjahr + 1) { $width = $y * $widthPerWeek; $x = $startX; $test = 5; } else { if (($year_beginn == $studienjahr && $kw_beginn < $kw_old || $year_beginn < $studienjahr) && ($year_end == $studienjahr && $kw_end >= $kw_old)) { $width = ($kw_end - $kw_old + 1) * $widthPerWeek; $x = $startX; $test = 6; } else { if (($year_beginn == $studienjahr && $kw_beginn < $kw_old || $year_beginn < $studienjahr) && ($year_end == $studienjahr + 1 && $kw_end <= $kw_new)) { if ($kw_end == 1) { // es kann auch sein dass 31.12 des kalenderjahres schon in der 1. KW liegt $kw_end = $kw_new; } $width = ($kw_gesamt - $kw_old + $kw_end + 1) * $widthPerWeek; $x = $startX; $test = 7; } else { if ($year_beginn == $studienjahr && $kw_beginn >= $kw_old && ($year_end == $studienjahr + 1 && $kw_end > $kw_new)) { $width = ($kw_gesamt - $kw_beginn + $kw_new + 1) * $widthPerWeek; $x = $startX + ($kw_beginn - $kw_old) * $widthPerWeek; $test = 8; } else { if ($year_beginn == $studienjahr && $kw_beginn > $kw_old && $year_end > $studienjahr + 1) { $width = ($kw_gesamt - $kw_beginn + $kw_new + 1) * $widthPerWeek; $x = $startX + ($kw_beginn - $kw_old) * $widthPerWeek; $test = 9; } else { if ($year_beginn == $studienjahr + 1 && $kw_beginn <= $kw_new && ($year_end == $studienjahr + 1 && ($kw_end > $kw_new || $kw_end == 1))) { $width = ($y - $kw_beginn - $startSS) * $widthPerWeek; $x = $startX + ($kw_beginn + $startSS) * $widthPerWeek; $test = 10; } else { if ($year_beginn == $studienjahr + 1 && $kw_beginn <= $kw_new && $year_end > $studienjahr + 1) { $width = ($y - $kw_beginn - $startSS) * $widthPerWeek; $x = $startX + ($kw_beginn + $startSS) * $widthPerWeek; $test = 11; } } } } } } } } } } } // zeichne balken $style = ''; $pr_phase = new projektphase(); $ende_phase = $phase->ende; $date_now = date('Y-m-d', time()); // check ob phase in vergangenheit liegt und noch nicht abgeschlossen ist -> markieren if (!$pr_phase->isPhaseErledigt($phase->projektphase_id) && $date_now > $ende_phase) { $style = 'style ="stroke:pink;stroke-width:10;"'; } echo '<rect x="' . $x . '" y="' . ($startY + 10 + $i * 50) . '" width ="' . $width . '" height ="30" fill="' . $phase->farbe . '" stroke="black" ' . $style . ' />'; echo '<text x="' . ($startX - 10) . '" y="' . ($startY + 30 + $i * 50) . '" style="font-size:15px" text-anchor="end">' . htmlspecialchars($phase->bezeichnung) . '</text>'; $i++; } echo '<text x="10%" y="' . (($i + 1) * 50 + $startY) . '" style="font-size:16px">Projekt: ' . htmlspecialchars($projekt->titel) . '</text>'; // aktuelle KW markieren $timestamp_now = time(); $kw_now = kalenderwoche($timestamp_now); $year_now = date("Y", $timestamp_now); if ($year_now == $studienjahr && $kw_now > $kw_old) { $x = $startX + ($kw_now - $kw_old) * $widthPerWeek - $widthPerWeek / 2; echo '<line x1="' . $x . '" y1="' . ($startY - 20) . '" x2="' . $x . '" y2="' . ($height + $startY + 20) . '" style="stroke:red; stroke-width:4px;" />'; } else { if ($year_now == $studienjahr + 1 && $kw_now < $kw_new) { $x = $startX + ($kw_now + $kw_gesamt - $kw_old + 1) * $widthPerWeek - $widthPerWeek / 2; echo '<line x1="' . $x . '" y1="' . ($startY - 20) . '" x2="' . $x . '" y2="' . ($height + $startY + 20) . '" style="stroke:red; stroke-width:4px;" />'; } } echo '</svg>'; } } }
/** * @param resource $connect * @param array $date_array * @param int $azubi * @return bool * * Prüft ob für einen Zeitrum x für den Azubi y * bereits eine finale Bewertung geschrieben wurde. */ function finale_vorhanden_pruefen($connect, $datum, $azubi, $anzahl) { //datum in Array umwandeln $date = datum_pruefen($datum); //Kalenderwoche ermitteln $date_array = kalenderwoche($date); $sql_final = 'SELECT id_bewertung FROM bewertungsparteien AS bp INNER JOIN zeitraum AS z ON bp.id_zeitraum=z.id_zeitraum WHERE z.von=\'' . pg_escape_string($connect, $date_array['von']) . '\' AND z.bis=\'' . pg_escape_string($connect, $date_array['bis']) . '\' AND bp.final=true'; if ($azubi) { $sql_final .= ' AND bp.id_bewerteter=' . pg_escape_string($connect, $azubi); } $result_final = execute_query($connect, $sql_final); if (pg_num_rows($result_final) > $anzahl) { return TRUE; } return false; }