예제 #1
0
파일: query.php 프로젝트: Molgju/bewertung
             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'];
     }
예제 #2
0
/**
 * 
 * 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>';
        }
    }
}
예제 #3
0
/**
 * @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;
}