# HG changeset patch # User Matti Hamalainen # Date 1294786862 -7200 # Node ID 57dd1db922c2334bc8bc19ef73acf43e21e2f342 # Parent 306028aa22536cffbef3cc5cb2190ecd6a29e52e Fix hours, add mini-info mode. diff -r 306028aa2253 -r 57dd1db922c2 beta.php --- a/beta.php Tue Jan 11 23:05:49 2011 +0200 +++ b/beta.php Wed Jan 12 01:01:02 2011 +0200 @@ -11,6 +11,22 @@ $infoURI = "http://www.oamk.fi/opiskelijalle/rakenne/opinto-opas/koulutusohjelmat/?sivu=oj&kieli=FI&opas=2010-2011&vuosi=10S11K&koodi1="; $dayNames = array("Maanantai", "Tiistai", "Keskiviikko", "Torstai", "Perjantai", "Lauantai", "Sunnuntai"); +$hourStamps = array( + array( 8, 15), + array( 9, 15), + array(10, 15), + array(11, 15), + array(12, 15), + array(13, 15), + array(14, 15), + array(15, 15), + array(16, 15), + array(17, 5), + array(18, 5), + array(19, 0), + array(20, 45), +); + // Include framework require "mcommon.inc.php"; require "merrors.inc.php"; @@ -32,7 +48,7 @@ // Check given parameters if (isset($_GET["luokka"])) { $luokka = $_GET["luokka"]; - if (checkClassID($luokka)) { + if (checkClassID($luokka) && !isset($_["nyt"])) { setcookie("lukluokka", $luokka, time() + 365*24*60*60); // expire in a year } } else @@ -59,7 +75,9 @@ function getHour($hour) { - return "
".($hour + 8).":15 - ".($hour + 9).":00

"; + global $hourStamps; + $stamp = mktime($hourStamps[$hour][0], $hourStamps[$hour][1], 0); + return "
".date("H:i", $stamp)." - ".date("H:i", $stamp + 45 * 60)."

"; } @@ -136,7 +154,7 @@ function printHourInfo($dayHours, $showDays) { - $out = " \n Tunteja (ryhmä)\n"; + $out = " \n Tunteja
(ryhmä/vv)\n"; for ($day = 0; $day < $showDays; $day++) { $out .= " ".$dayHours[$day]["total"]."h (".$dayHours[$day]["grouped"]."h)\n"; } @@ -149,15 +167,104 @@ global $classHourTable, $classInfo; $n = 0; for ($i = $start; $i < $classInfo["maxhours"]; $i++) - if ($classHourTable[$i][$day] == $cmp) { - if ($mark) $classHourTable[$i][$day] = -9999; - $n++; - } else - break; + if ($classHourTable[$i][$day] == $cmp) { + if ($mark) $classHourTable[$i][$day] = -9999; + $n++; + } else + break; return $n; } +function findNextHour(&$j, &$i, $day, $hour, $chk) +{ + global $classInfo, $classHourTable; + for ($j = $day; $j < $classInfo["maxdays"]; $j++) + for ($i = $hour; $i < $classInfo["maxhours"]; $i++) { +// echo "chk=$chk - i=$i / j=$j : ht=".$classHourTable[$i][$j]."
\n"; + if (($chk > 0 && $classHourTable[$i][$j] != $chk) || $classHourTable[$i][$j] > 0) + return $classHourTable[$i][$j]; + } + + return -1; +} + + +function getHourInfo($id) +{ + global $classDefs; + + if (isset($id)) { + if ($id >= 0 && isset($classDefs[$id])) { + $i = $classDefs[$id]; + $d = $i["data"]; + $out = ""; + + $isSplit = preg_match("/^[A-Z]\d{6}$/", $d[1]); + if ($isSplit) { + $out .= "". + ""; + for ($j = 2; $j < count($d); $j += 2) + $out .= ""; + $out .= "
".matchCourse($d[0])."".matchCourse($d[1])."
".htmlentities($d[$j])."".(isset($d[$j+1]) ? htmlentities($d[$j+1]) : "")."
"; + } else { + $out .= matchCourse($d[0])."
"; + for ($j = 1; $j < count($d); $j++) + $out .= htmlentities($d[$j])."
"; + } + + return $out; + } else + return "

Ei tunteja.

"; + } else + return "

Ei mitään.

"; + + return ""; +} + + +if (isset($_GET["nyt"])) { + $aika = getdate(); + $hour = $aika["hours"] - 8; + $day = $aika["wday"] - 1; + if ($day < 0) $day = 7; + + $chk = $classHourTable[$hour][$day]; + + $out = "

".$dayNames[$day]." ".$aika["mday"].".".$aika["mon"].".".$aika["year"]." - klo ".$aika["hours"].":".$aika["minutes"]."

\n". + getHourInfo($chk)."\n"; + +// $out .= "hour=".$hour."/day=".$day."
\n"; + if ($day >= $classInfo["maxdays"]) { + $day = $hour = 0; + $chk = -1; + } else + if ($hour < 0) { + $hour = 0; + $chk = -1; + } else + if ($hour >= $classInfo["maxhours"]) { + $day++; + $hour = 0; + $chk = -1; + } +// $out .= "hour=".$hour."/day=".$day."
\n"; + + $found = findNextHour($nday, $nhour, $day, $hour, $chk); + +// $out .= "hour=".$nhour."/day=".$nday."/found=".$found."
\n"; + + if ($found > 0) { + $stamp = mktime(8 + $nhour, 15, 0, $aika["mon"], $aika["mday"] + $nday - $day, $aika["year"]); + $aika = getdate($stamp); + $hour = $aika["hours"] - 8; + $day = $aika["wday"] - 1; + if ($day < 0) $day = 7; + $out .= "

Seuraavaksi: ".$dayNames[$nday]." ".date("d.n.Y", $stamp)." - klo ".date("H:i", $stamp)."

\n". + getHourInfo($found)."\n"; + } +} +else if ($haveData) { $totalHours = 0; $totalGrouped = 0; @@ -253,12 +360,23 @@ echo "

".$pageTitle."

\n"; echo "
\n". -" \n"; foreach ($classes as $class) { - echo " \n"; + echo " \n"; } -echo " \n \n
\n"; +echo +" \n". +" \n". +" \n". +" [Mini-info moodi]\n". +" \n". +" \n". +"\n"; + // Show error messages if ($errorSet) {