function saradnik_grupa() { global $userid, $user_siteadmin; require "lib/manip.php"; print '<p><a href="index.php?sta=saradnik/intro">Spisak predmeta i grupa</a></p>' . "\n"; // ------- ULAZNI PARAMETRI $labgrupa = intval($_REQUEST['id']); $kreiranje = intval($_GET['kreiranje']); if ($labgrupa > 0) { // Određujemo predmet i ag za labgrupu $q30 = myquery("select naziv, predmet, akademska_godina, virtualna from labgrupa where id={$labgrupa}"); if (mysql_num_rows($q30) < 1) { biguglyerror("Nemate pravo ulaska u ovu grupu!"); zamgerlog("nepostojeca labgrupa {$labgrupa}", 3); // 3 = greska zamgerlog2("nepostojeca labgrupa", $labgrupa); return; } $naziv = mysql_result($q30, 0, 0); $predmet = mysql_result($q30, 0, 1); $ag = mysql_result($q30, 0, 2); $virtualna = mysql_result($q30, 0, 3); } else { // Ako nije definisana grupa, probacemo preko predmeta i ag uci u virtuelnu grupu $predmet = intval($_REQUEST['predmet']); $ag = intval($_REQUEST['ag']); $q35 = myquery("select id, naziv from labgrupa where predmet={$predmet} and akademska_godina={$ag} and virtualna=1"); if (mysql_num_rows($q35) < 1) { biguglyerror("Nemate pravo ulaska u ovu grupu!"); zamgerlog("nepostojeca virtualna labgrupa za predmet pp{$predmet} ag{$ag}", 3); // 3 = greska zamgerlog2("nepostojeca virtualna labgrupa", $predmet, $ag); return; } $labgrupa = mysql_result($q35, 0, 0); $naziv = mysql_result($q35, 0, 1); $virtualna = 1; } // Da li korisnik ima pravo ući u grupu? if (!$user_siteadmin) { $q40 = myquery("select nivo_pristupa from nastavnik_predmet where nastavnik={$userid} and predmet={$predmet} and akademska_godina={$ag}"); if (mysql_num_rows($q40) < 1) { biguglyerror("Nemate pravo ulaska u ovu grupu!"); zamgerlog("nastavnik nije na predmetu (labgrupa g{$labgrupa})", 3); zamgerlog2("nije saradnik na predmetu", $predmet, $ag); return; } $privilegija = mysql_result($q40, 0, 0); $q50 = myquery("select o.labgrupa from ogranicenje as o, labgrupa as l where o.nastavnik={$userid} and o.labgrupa=l.id and l.predmet={$predmet} and l.akademska_godina={$ag}"); if (mysql_num_rows($q50) > 0) { $nasao = 0; while ($r50 = mysql_fetch_row($q50)) { if ($r50[0] == $labgrupa) { $nasao = 1; break; } } if ($nasao == 0) { biguglyerror("Nemate pravo ulaska u ovu grupu!"); zamgerlog("ogranicenje na labgrupu g{$labgrupa}", 3); // 3 - greska zamgerlog2("ima ogranicenje na labgrupu", $labgrupa); return; } } } // Spisak komponenti koje su zastupljene na predmetu $tipovi_komponenti = array(); $q52 = myquery("select k.id, k.tipkomponente from akademska_godina_predmet as agp, tippredmeta_komponenta as tpk, komponenta as k where agp.akademska_godina={$ag} and agp.predmet={$predmet} and agp.tippredmeta=tpk.tippredmeta and tpk.komponenta=k.id"); while ($r52 = mysql_fetch_row($q52)) { $tipovi_komponenti[$r52[0]] = $r52[1]; } // ------- AKCIJE // Dodavanje casa if ($_POST['akcija'] == 'dodajcas' && check_csrf_token()) { // KOMPONENTA // Ovaj kod radi samo sa jednom komponentom prisustva. U budućnosti to bi moglo biti popravljeno, ali realno nema prevelike potrebe $datum = intval($_POST['godina']) . "-" . intval($_POST['mjesec']) . "-" . intval($_POST['dan']); $vrijeme = $_POST['vrijeme']; if (!preg_match("/^\\d?\\d\\:\\d\\d\$/", $vrijeme)) { niceerror("Vrijeme nije u ispravnom formatu!"); print "<p>Vrijeme mora biti oblika HH:MM, a vi ste unijeli '{$vrijeme}'.</p>"; print "<p><a href=\"?sta=saradnik/grupa&id={$labgrupa}\">Nazad</a></p>"; return; } $predavanje = intval($_POST['predavanje']); // Ako se klikne na refresh, datum moze biti 0-0-0... if ($datum != "0-0-0") { // Tražimo komponentu prisustva i uzimamo prvu // FIXME: praktično je nemoguće registrovati čas za drugu komponentu $komponenta = 0; foreach ($tipovi_komponenti as $k_id => $tip) { if ($tip == 3) { // 3 = prisustvo $komponenta = $k_id; break; } } if ($komponenta == 0) { niceerror("Nije definisana komponenta za prisustvo na ovom predmetu."); zamgerlog("nije definisana komponenta za prisustvo na pp{$predmet}", 3); zamgerlog2("nije definisana komponenta za prisustvo", $predmet, $ag); return; } $kviz = intval($_REQUEST['kviz']); $q60 = myquery("insert into cas set datum='{$datum}', vrijeme='{$vrijeme}', labgrupa={$labgrupa}, nastavnik={$userid}, komponenta={$komponenta}, kviz={$kviz}"); $cas_id = mysql_insert_id(); // Max bodova za komponentu $q75 = myquery("select maxbodova, opcija from komponenta where id={$komponenta}"); $maxbodova = mysql_result($q75, 0, 0); $opcija = mysql_result($q75, 0, 1); // dodajemo u bazu default podatke za prisustvo i ocjene $q80 = myquery("select student from student_labgrupa where labgrupa={$labgrupa}"); while ($r80 = mysql_fetch_row($q80)) { $stud_id = $r80[0]; $prisustvo = intval($_POST['prisustvo']); // Potrebna nam je ponudakursa za update_komponente $q53 = myquery("select sp.predmet from student_predmet as sp, ponudakursa as pk where sp.student={$stud_id} and sp.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina={$ag}"); $ponudakursa = mysql_result($q53, 0, 0); $q90 = mysql_query("insert into prisustvo set student={$stud_id}, cas={$cas_id}, prisutan={$prisustvo}"); // Update radimo samo ako se registruje odsustvo ili ako je opcija=-1 (proporcionalni bodovi) if ($prisustvo == 0 || $opcija == -1) { update_komponente($stud_id, $ponudakursa, $komponenta); } else { // Ako nema uopšte bodova za komponentu, ubacićemo broj bodova $q95 = myquery("select count(*) from komponentebodovi where student={$stud_id} and predmet={$ponudakursa} and komponenta={$komponenta}"); if (mysql_result($q95, 0, 0) == 0) { $q97 = myquery("insert into komponentebodovi set student={$stud_id}, predmet={$ponudakursa}, komponenta={$komponenta}, bodovi={$maxbodova}"); } } } // Ako je odabrano "sa kvizom" kreiramo kviz if ($kviz > 0) { $q98 = myquery("select trajanje_kviza from kviz where id={$kviz}"); $trajanje = mysql_result($q98, 0, 0) * 2; $q99 = myquery("update kviz set vrijeme_pocetak=NOW(), vrijeme_kraj=NOW() + INTERVAL {$trajanje} SECOND, labgrupa={$labgrupa} where id={$kviz}"); } zamgerlog("registrovan cas c{$cas_id}", 2); // nivo 2: edit zamgerlog2("registrovan cas", $cas_id); } } // Brisanje casa if ($_POST['akcija'] == 'brisi_cas' && check_csrf_token()) { $cas_id = intval($_POST['_lv_casid']); // Updatujemo komponentu svima koji su bili prisutni $q103 = myquery("select komponenta from cas where id={$cas_id}"); if (mysql_num_rows($q103) > 0) { $komponenta = mysql_result($q103, 0, 0); $q105 = myquery("select sp.student, sp.predmet from prisustvo as pr, student_predmet as sp, ponudakursa as pk where pr.cas={$cas_id} and pr.student=sp.student and sp.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina={$ag}"); $studenti = $ponudekursa = array(); while ($r105 = mysql_fetch_row($q105)) { array_push($studenti, $r105[0]); $ponudekursa[$r105[0]] = $r105[1]; } $q100 = myquery("delete from prisustvo where cas={$cas_id}"); $q110 = myquery("delete from cas where id={$cas_id}"); foreach ($studenti as $student) { update_komponente($student, $ponudekursa[$student], $komponenta); } zamgerlog("obrisan cas {$cas_id}", 2); zamgerlog2("obrisan cas", $cas_id); } } // ------- ZAGLAVLJE STRANICE (naslov i sl.) $q130 = myquery("select naziv from predmet where id={$predmet}"); $pime = mysql_result($q130, 0, 0); // Ne bi se smjelo desiti da je nepostojeci predmet, posto se to odredjuje iz labgrupe ?> <br /> <center><h1><?php echo $pime; ?> - <?php echo $naziv; ?> </h1></center> <?php // Ima li ikoga u grupi? $q140 = myquery("select count(student) from student_labgrupa where labgrupa={$labgrupa}"); if (mysql_result($q140, 0, 0) < 1) { print "<p>Nijedan student nije u grupi</p>\n"; return; } // JavaScript za prikaz popup prozora (trenutno se koristi samo za komentare) // * FF ne podržava direktan poziv window.open() iz eventa ?> <script language="JavaScript"> function firefoxopen(p1,p2,p3) { window.open(p1,p2,p3); } </script> <?php // Cool editing box if ($privilegija == "nastavnik" || $privilegija == "super_asistent" || $user_siteadmin) { cool_box('ajah_start("index.php?c=N&sta=common/ajah&akcija=izmjena_ispita&idpolja="+zamger_coolbox_origcaller.id+"&vrijednost="+coolboxedit.value, "undo_coolbox()", "zamger_coolbox_origcaller=false");'); ?> <script language="JavaScript"> function undo_coolbox() { var greska = document.getElementById("zamger_ajah-info").innerText || document.getElementById("zamger_ajah-info").textContent; if (!greska.match(/\S/)) greska = "Došlo je do greške. Molimo kontaktirajte administratora."; alert(greska); zamger_coolbox_origcaller.innerHTML = zamger_coolbox_origvalue; zamger_coolbox_origcaller=false; } </script> <?php } // ------- SPISAK NEPREGLEDANIH ZADAĆA if (in_array(4, $tipovi_komponenti)) { // 4 = zadaće // JavaScript za prikaz popup prozora sa zadaćom // * Kod IE naslov prozora ('zadaca') ne smije sadržavati razmak i // ne smije biti prazan, a inače je nebitan ?> <script language="JavaScript"> function openzadaca(e, student,zadaca,zadatak) { var evt = e || window.event; var url='index.php?sta=saradnik/zadaca&student='+student+'&zadaca='+zadaca+'&zadatak='+zadatak; if (evt.shiftKey) window.open(url,'_blank','width=600,height=600,scrollbars=yes'); else window.open(url,'zadaca','width=600,height=600,scrollbars=yes'); } </script> <?php $q150 = myquery("SELECT zk.zadaca, zk.redni_broj, zk.student, a.ime, a.prezime, zk.status, z.naziv\n\tFROM zadatak as zk, osoba as a, student_labgrupa as sl, zadaca as z\n\tWHERE zk.student=a.id AND zk.student=sl.student \n\tAND sl.labgrupa={$labgrupa} AND zk.zadaca=z.id AND z.predmet={$predmet} AND z.akademska_godina={$ag}\n\tORDER BY zk.zadaca, zk.redni_broj, a.prezime, a.ime, zk.id DESC"); $mzadaca = 0; $mzadatak = 0; $mstudent = 0; $print = ""; while ($r150 = mysql_fetch_row($q150)) { if ($r150[0] == $mzadaca && $r150[1] == $mzadatak && $r150[2] == $mstudent) { continue; } $mzadaca = $r150[0]; $mzadatak = $r150[1]; $mstudent = $r150[2]; if ($r150[5] != 4) { continue; } $print .= '<li><a href="#" onclick="javascript:openzadaca(event, \'' . $r150[2] . '\',\'' . $r150[0] . '\',\'' . $r150[1] . '\')">' . $r150[3] . " " . $r150[4] . " - " . $r150[6] . ", zadatak " . $r150[1] . "</a></li>"; } if ($print != "") { print "<h2>Nove zadaće za pregled:</h2>\n<ul>{$print}</ul>"; } } // ------- FORMA ZA NOVI ČAS if (in_array(3, $tipovi_komponenti)) { // 3 = prisustvo $dan = date("d"); $mjesec = date("m"); $godina = date("Y"); $vrijeme = date("H:i"); // Ujedno ćemo definisati i neke JavaScripte za prisustvo ?> <table border="0" width="100%"><tr><td valign="top" width="50%"> </td> <td valign="top" width="50%"> Registrujte novi čas:<br/> <?php echo genform("POST"); ?> <input type="hidden" name="akcija" value="dodajcas"> Datum: <select name="dan" class="default"><?php for ($i = 1; $i <= 31; $i++) { print "<option value=\"{$i}\""; if ($i == $dan) { print " selected"; } print ">{$i}</option>"; } ?> </select> <select name="mjesec" class="default"><?php for ($i = 1; $i <= 12; $i++) { print "<option value=\"{$i}\""; if ($i == $mjesec) { print " selected"; } print ">{$i}</option>"; } ?> </select> <select name="godina" class="default"><?php for ($i = 2005; $i <= 2020; $i++) { print "<option value=\"{$i}\""; if ($i == $godina) { print " selected"; } print ">{$i}</option>"; } ?> </select><br/> Vrijeme: <input type="text" size="10" name="vrijeme" value="<?php echo $vrijeme; ?> " class="default"> <input type="submit" value="Registruj" class="default"><br/><br/> <input type="radio" name="prisustvo" value="1" CHECKED>Svi prisutni <input type="radio" name="prisustvo" value="0">Svi odsutni <?php // Kreiraj čas sa kvizom $q160 = myquery("select smp.aktivan from studentski_modul_predmet as smp, studentski_modul as sm where smp.predmet={$predmet} and smp.akademska_godina={$ag} and smp.studentski_modul=sm.id and sm.modul='student/kviz'"); if (mysql_num_rows($q160) > 0 && mysql_result($q160, 0, 0) == 1) { ?> <br> Sa kvizom: <select name="kviz"><option value="0">/</option> <?php $q170 = myquery("select id,naziv from kviz where predmet={$predmet} and akademska_godina={$ag} and aktivan=1"); while ($r170 = mysql_fetch_row($q170)) { print "<option value=\"{$r170['0']}\">{$r170['1']}</option>\n"; } ?> </select> <?php } ?> </form> </td></tr></table> <script language="JavaScript"> var oldState = 0; var oldEvent; // Funkcija koja se poziva klikom na polje u tabeli function prisustvo(e,student,cas) { if (zamger_ajah_sending) { alert("Slanje u toku. Sačekajte malo."); return false; } var prisutan = invert(e,student,cas); ajah_start("index.php?c=N&sta=common/ajah&akcija=prisustvo&student="+student+"&cas="+cas+"&prisutan="+prisutan, "undo_prisustvo("+student+","+cas+","+prisutan+")"); } // Funkcija koja se poziva u slučaju greške sa prisustvom function undo_prisustvo(student,cas,prisutan) { var greska = document.getElementById("zamger_ajah-info").innerText || document.getElementById("zamger_ajah-info").textContent; if (!greska.match(/\S/)) greska = "Došlo je do greške. Molimo kontaktirajte administratora."; alert(greska); invert(oldEvent, student, cas); } // Switchuje DA i NE function invert(e,student,cas) { var val = document.getElementById("danetekst-"+student+"-"+cas).innerHTML; var evt = e || window.event; oldEvent = e; // Shift služi za pristup neutralnom stanju / if (evt.shiftKey) { if (oldState == 0) { if (val == "DA") oldState = 1; else oldState = 2; document.getElementById("dane-"+student+"-"+cas).style.background = "#FFFFCC"; document.getElementById("danetekst-"+student+"-"+cas).innerHTML = "/"; return 3; } else { if (oldState==1) val="NE"; else val="DA"; // Invertujemo sa NE na DA i obrnuto oldState=0; } } if (val == "DA") { document.getElementById("dane-"+student+"-"+cas).style.background = "#FFCCCC"; document.getElementById("danetekst-"+student+"-"+cas).innerHTML = "NE"; return 1; } else { document.getElementById("dane-"+student+"-"+cas).style.background="#CCFFCC"; document.getElementById("danetekst-"+student+"-"+cas).innerHTML = "DA"; return 2; } } function upozorenje(cas) { if (confirm("Da li ste sigurni da želite obrisati čas?")) { // _lv_casid osigurava da genform() neće dodati još jedno hidden polje document.brisanjecasa._lv_casid.value=cas; document.brisanjecasa.submit(); } return false; } </script> <!-- Pomocna forma za POST brisanje casa --> <?php echo genform("POST", "brisanjecasa"); ?> <input type="hidden" name="akcija" value="brisi_cas"> <input type="hidden" name="_lv_casid" value=""> </form> <?php } // if (in_array(3, $tipovi_komponenti)) // Ispis AJAH box-a neposredno iznad tablice grupe print ajah_box(); // ------- TABLICA GRUPE - ZAGLAVLJE $minw = 0; // minimalna sirina tabele $mogucih_bodova = 0; // koliko bodova su studenti mogli osvojiti, radi procenta $zaglavlje1 = ""; $zaglavlje2 = ""; $prisustvo_id_array = array(); // Zaglavlje prisustvo $q195 = myquery("SELECT k.id, k.gui_naziv, k.maxbodova FROM akademska_godina_predmet as agp, tippredmeta_komponenta as tpk, komponenta as k\nWHERE agp.predmet={$predmet} and agp.akademska_godina={$ag} and agp.tippredmeta=tpk.tippredmeta and tpk.komponenta=k.id and k.tipkomponente=3 ORDER BY k.id"); // Ako nema nijedne komponente prisustva, upit neće vratiti ništa while ($r195 = mysql_fetch_row($q195)) { $casova = 0; $prisustvo_zaglavlje = ""; $prisustvo_id_array[] = $r195[0]; $cas_id_array = array(); $cas_kviz_array = array(); $q200 = myquery("SELECT id,datum,vrijeme,kviz FROM cas where labgrupa={$labgrupa} and komponenta={$r195['0']} ORDER BY datum, vrijeme"); while ($r200 = mysql_fetch_row($q200)) { $cas_id = $r200[0]; list($cas_godina, $cas_mjesec, $cas_dan) = explode("-", $r200[1]); list($cas_sat, $cas_minuta, $cas_sekunda) = explode(":", $r200[2]); $prisustvo_zaglavlje .= "<td align=\"center\">{$cas_dan}.{$cas_mjesec}<br/>{$cas_sat}:{$cas_minuta}"; $prisustvo_zaglavlje .= '<br/><a href="javascript:onclick=upozorenje(' . "'{$cas_id}'" . ');"><img src="images/16x16/brisanje.png" border="0"></a>'; $prisustvo_zaglavlje .= "</td>\n"; $cas_id_array[] = $cas_id; $casova++; $minw += 40; // Kviz if ($r200[3] > 0) { $cas_kviz[$cas_id] = $r200[3]; // Odredjujemo bodove za prolaz $q202 = myquery("select prolaz_bodova from kviz where id={$r200['3']}"); $cas_kviz_prolaz[$cas_id] = mysql_result($q202, 0, 0); // Ako sam nekom drugom casu ranije dao ovaj id, moram ga obrisati foreach ($cas_id_array as $cid) { if ($cid == $cas_id) { continue; } if ($cas_kviz[$cid] == $r200[3]) { $cas_kviz[$cid] = 0; } } } else { // Ako kviz nije unesen u bazu, tražimo najbliži $q203 = myquery("select id, prolaz_bodova from kviz where predmet={$predmet} and akademska_godina={$ag} and vrijeme_pocetak>='{$r200['1']}' and vrijeme_pocetak<'{$r200['1']}' + interval 5 day order by vrijeme_pocetak desc"); while ($r203 = mysql_fetch_row($q203)) { // Da li je već bio? $bio = false; foreach ($cas_id_array as $cid) { if ($cas_kviz[$cid] == $r203[0]) { $bio = true; } } if ($bio) { continue; } $cas_kviz[$cas_id] = $r203[0]; $cas_kviz_prolaz[$cas_id] = $r203[1]; break; } } } $prisustvo_casovi[$r195[0]] = $cas_id_array; // $prisustvo_maxbodova[$r195[0]] = $r195[2]; // $prisustvo_maxizostanaka[$r195[0]] = $r195[3]; // $prisustvo_minbodova[$r195[0]] = $r195[4]; $mogucih_bodova += $r195[2]; if ($prisustvo_zaglavlje == "") { $prisustvo_zaglavlje = "<td> </td>"; $minw += 40; $casova = 1; } $zaglavlje1 .= "<td align=\"center\" colspan=\"" . ($casova + 1) . "\">{$r195['1']}</td>\n"; $zaglavlje2 .= $prisustvo_zaglavlje; $zaglavlje2 .= "<td>BOD.</td>\n"; } // Zaglavlje zadaće $zad_id_array = array(); $q205 = myquery("SELECT k.id, k.gui_naziv FROM akademska_godina_predmet as agp, tippredmeta_komponenta as tpk, komponenta as k\nWHERE agp.predmet={$predmet} and agp.akademska_godina={$ag} and agp.tippredmeta=tpk.tippredmeta and tpk.komponenta=k.id and k.tipkomponente=4 ORDER BY k.id"); // Ako nema nijedne komponente zadaća, upit neće vratiti ništa while ($r205 = mysql_fetch_row($q205)) { $brzadaca = 0; $zadace_zaglavlje = ""; $komponenta = $r205[0]; // Razvrstavamo zadaće po komponentama $q210 = myquery("select id,naziv,zadataka,bodova from zadaca where predmet={$predmet} and akademska_godina={$ag} and komponenta={$komponenta} order by id"); while ($r210 = mysql_fetch_row($q210)) { $zadace_zaglavlje .= "<td width=\"60\" align=\"center\">{$r210['1']}<br /><a href=\"?sta=saradnik/svezadace&grupa={$labgrupa}&zadaca={$r210['0']}\">Download</a></td>\n"; $zad_id_array[] = $r210[0]; $zad_brz_array[$r210[0]] = $r210[2]; $mogucih_bodova += $r210[3]; $brzadaca++; $minw += 60; } if ($brzadaca > 0) { $zaglavlje1 .= "<td align=\"center\" colspan=\"{$brzadaca}\">{$r205['1']}</td>\n"; $zaglavlje2 .= $zadace_zaglavlje; } } // Zaglavlje fiksne komponente $fiksna_prolaz = array(); $fiksna_id_array = array(); $q215 = myquery("SELECT k.id, k.gui_naziv, k.maxbodova, k.prolaz FROM akademska_godina_predmet as agp, tippredmeta_komponenta as tpk, komponenta as k\nWHERE agp.predmet={$predmet} and agp.akademska_godina={$ag} and agp.tippredmeta=tpk.tippredmeta and tpk.komponenta=k.id and k.tipkomponente=5 ORDER BY k.id"); // Ako nema nijedne fiksne komponente, upit neće vratiti ništa while ($r215 = mysql_fetch_row($q215)) { $zaglavlje1 .= "<td align=\"center\" rowspan=\"2\">{$r215['1']}"; $mogucih_bodova += $r215[2]; $minw += 60; $fiksna_id_array[] = $r215[0]; $fiksna_prolaz[$r215[0]] = $r215[3]; } // Zaglavlje ispiti $broj_ispita = 0; $ispit_zaglavlje = ""; $ispit_id_array = array(); $q220 = myquery("select i.id, UNIX_TIMESTAMP(i.datum), k.id, k.kratki_gui_naziv, k.tipkomponente, k.maxbodova, k.prolaz, k.opcija from ispit as i, komponenta as k where i.predmet={$predmet} and i.akademska_godina={$ag} and i.komponenta=k.id order by i.datum,i.komponenta"); // Ako nema komponenti sa ispitima, neće biti registrovan nijedan ispit while ($r220 = mysql_fetch_row($q220)) { if ($r220[4] == 5) { $ispit_zaglavlje .= "<td align=\"center\">{$r220['3']}</td>\n"; } else { $ispit_zaglavlje .= "<td align=\"center\">{$r220['3']}<br/> " . date("d.m.", $r220[1]) . "</td>\n"; } $ispit_id_array[] = $r220[0]; $ispit_komponenta[$r220[0]] = $r220[2]; // Pripremamo podatke o komponentama $komponenta_tip[$r220[2]] = $r220[4]; $komponenta_maxb[$r220[2]] = $r220[5]; $komponenta_prolaz[$r220[2]] = $r220[6]; $komponenta_opcija[$r220[2]] = "{$r220['7']}"; if ($r220[4] != 2) { $mogucih_bodova += $r220[5]; } $minw += 40; $broj_ispita++; } if ($broj_ispita > 0) { $zaglavlje1 .= "<td align=\"center\" colspan=\"{$broj_ispita}\">Ispiti</td>\n"; $zaglavlje2 .= $ispit_zaglavlje; } // Zaglavlje konacna ocjena //$ispis_konacna=0; //$q230 = myquery("select count(*) from konacna_ocjena where predmet=$predmet_id"); //if (mysql_result($q230,0,0)>0) { // $minw += 40; $ispis_konacna = 1; //} //if ($casova==0) $casova=1; // ISPIS ZAGLAVLJA $minw += 70; // ukupno $minw += 45; // broj indexa $minw += 100; // ime i prezime $minw += 40; // komentar $minw += 40; // bodovi prisustvo ?> <table cellspacing="0" cellpadding="2" border="1" <?php if ($minw > 800) { print "width=\"{$minw}\""; } ?> > <tr> <td rowspan="2" align="center" valign="center">Ime i prezime</td> <td rowspan="2" align="center" valign="center">Broj indexa</td> <td rowspan="2" align="center" valign="center">Ko-<br/>men-<br/>tar</td> <?php echo $zaglavlje1; ?> <td align="center" valign="center" rowspan="2"> <b>UKUPNO</b> </td> <?php if ($ispis_konacna == 1) { ?> <td rowspan="2" align="center">Konačna<br/>ocjena</td><?php } ?> </tr> <tr> <?php echo $zaglavlje2; ?> <?php if ($ispis_usmeni == 1) { ?> <td>Usmeni</td><?php } ?> </tr> <?php // CACHE REZULTATA ZADAĆA $zadace_statusi = array(); $zadace_bodovi = array(); $q300 = myquery("SELECT z.zadaca,z.redni_broj,z.student,z.status,z.bodova\nFROM zadatak as z,student_labgrupa as sl \nWHERE z.student=sl.student and sl.labgrupa={$labgrupa}\nORDER BY z.id"); while ($r300 = mysql_fetch_row($q300)) { // Slog sa najnovijim IDom se smatra mjerodavnim // Ostali su u bazi radi historije $zadace_bodovi[$r300[0]][$r300[1]][$r300[2]] = $r300[4]; $zadace_statusi[$r300[0]][$r300[1]][$r300[2]] = $r300[3] + 1; // Dodajemo 1 na status kako bismo kasnije mogli znati da li // je vrijednost niza definisana ili ne. // undef ne radi :( } // Ikone i statusi za zadaće $stat_icon = array("zad_bug", "zad_cekaj", "zad_copy", "zad_bug", "zad_preg", "zad_ok"); $stat_tekst = array("Bug u programu", "Automatsko testiranje u toku", "Zadaća prepisana", "Bug u programu", "Potrebno pregledati", "Zadaća OK"); // Glavna petlja - studenti $q310 = myquery("select a.id,a.ime,a.prezime,a.brindexa from osoba as a,student_labgrupa as sl where a.id=sl.student and sl.labgrupa={$labgrupa}"); $imeprezime = array(); $brind = array(); while ($r310 = mysql_fetch_row($q310)) { $stud_id = $r310[0]; $stud_ime = $r310[1]; $stud_prezime = $r310[2]; $stud_brind = $r310[3]; $imeprezime[$stud_id] = "{$stud_prezime} {$stud_ime}"; $brind[$stud_id] = $stud_brind; // Dodajemo ime grupe pored imena studenta ako je grupa virtualna if ($grupa_virtualna == 1) { $q315 = myquery("select lg.naziv from labgrupa as lg, student_labgrupa as sl where sl.student={$stud_id} and sl.labgrupa=lg.id and lg.virtualna=0 and lg.predmet={$predmet} and lg.akademska_godina={$ag}"); if (mysql_num_rows($q315) > 0) { $stud_ime .= " (" . mysql_result($q315, 0, 0) . ")"; } } } uasort($imeprezime, "bssort"); // bssort - bosanski jezik $redni_broj = 0; foreach ($imeprezime as $stud_id => $stud_imepr) { $rednibroj++; ?> <tr> <td id="student_<?php echo $stud_id; ?> "><?php echo $rednibroj; ?> . <a href="index.php?sta=saradnik/student&student=<?php echo $stud_id; ?> &predmet=<?php echo $predmet; ?> &ag=<?php echo $ag; ?> "><?php echo $stud_imepr; ?> </a></td> <td><?php echo $brind[$stud_id]; ?> </td> <td align="center"><a href="javascript:firefoxopen('index.php?sta=saradnik/komentar&student=<?php echo $stud_id; ?> &labgrupa=<?php echo $labgrupa; ?> ','blah3','width=350,height=320,status=0,toolbar=0,resizable=1,location=0,menubar=0,scrollbars=1');"><img src="images/16x16/komentar-plavi.png" border="0" width="16" height="16" alt="Komentar na rad studenta" title="Komentar na rad studenta"></a></td> <?php $prisustvo_ispis = $zadace_ispis = $ispiti_ispis = ""; $bodova = 0; // PRISUSTVO - ISPIS foreach ($prisustvo_id_array as $pid) { $cas_id_array = $prisustvo_casovi[$pid]; if (count($cas_id_array) == 0) { $prisustvo_ispis .= "<td> </td>"; } $odsustvo = 0; foreach ($cas_id_array as $cid) { // Postoji li kviz za ovaj čas? $uspjeh_na_kvizu = ""; if ($cas_kviz[$cid] > 0) { $q317 = myquery("select dovrsen, bodova from kviz_student where student={$stud_id} and kviz=" . $cas_kviz[$cid]); if (mysql_num_rows($q317) > 0) { if (mysql_result($q317, 0, 0) == 1 && mysql_result($q317, 0, 1) >= $cas_kviz_prolaz[$cid]) { $uspjeh_na_kvizu = '<img src="images/16x16/zad_ok.png" width="8" height="8">'; } else { $uspjeh_na_kvizu = '<img src="images/16x16/brisanje.png" width="8" height="8">'; } } } $q320 = myquery("select prisutan from prisustvo where student={$stud_id} and cas={$cid}"); if (mysql_num_rows($q320) > 0) { if (mysql_result($q320, 0, 0) == 1) { $prisustvo_ispis .= "<td bgcolor=\"#CCFFCC\" align=\"center\" id=\"dane-" . $stud_id . "-" . $cid . "\" onclick=\"javascript:prisustvo(event," . $stud_id . "," . $cid . ")\"><span id=\"danetekst-" . $stud_id . "-" . $cid . "\">DA</span> {$uspjeh_na_kvizu}</td>"; } else { $prisustvo_ispis .= "<td bgcolor=\"#FFCCCC\" align=\"center\" id=\"dane-" . $stud_id . "-" . $cid . "\" onclick=\"javascript:prisustvo(event," . $stud_id . "," . $cid . ")\"><span id=\"danetekst-" . $stud_id . "-" . $cid . "\">NE</span> {$uspjeh_na_kvizu}</td>"; $odsustvo++; } //$ocj = mysql_result($q14,0,1); } else { $prisustvo_ispis .= "<td bgcolor=\"#FFFFCC\" align=\"center\" id=\"dane-" . $stud_id . "-" . $cid . "\" onclick=\"javascript:prisustvo(event," . $stud_id . "," . $cid . ")\"><div id=\"danetekst-" . $stud_id . "-" . $cid . "\"> / </div> {$uspjeh_na_kvizu}</td>"; } } /* if ($odsustvo<=$prisustvo_maxizostanaka[$pid]) { $prisustvo_ispis .= "<td>".$prisustvo_maxbodova[$pid]."</td>"; $bodova+=10; } else { $prisustvo_ispis .= "<td>".$prisustvo_minbodova[$pid]."</td>"; }*/ $q325 = myquery("select kb.bodovi from komponentebodovi as kb, ponudakursa as pk where kb.student={$stud_id} and kb.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina={$ag} and kb.komponenta={$pid}"); if (mysql_num_rows($q325) == 0) { $pbodovi = 0; } else { $pbodovi = mysql_result($q325, 0, 0); } $prisustvo_ispis .= "<td>{$pbodovi}</td>\n"; $bodova += $pbodovi; } // foreach ($prisustvo... as $pid) // ZADACE - ISPIS foreach ($zad_id_array as $zid) { $zadace_ispis .= "<td>\n"; // FIXME: subqueries //$q15a = myquery ("select redni_broj from zadatak where zadaca=$zid and student=$stud_id order by redni_broj group by redni_broj"); for ($i = 1; $i <= $zad_brz_array[$zid]; $i++) { $status = $zadace_statusi[$zid][$i][$stud_id]; if ($status == 0) { // Zadatak nije poslan if ($kreiranje > 0) { $zadace_ispis .= "<a href=\"#\" onclick=\"javascript:openzadaca(event, '" . $stud_id . "', '" . $zid . "', '" . $i . "'); return false;\"><img src=\"images/16x16/zad_novi.png\" width=\"16\" height=\"16\" border=\"0\" align=\"center\" title=\"" . $stud_id . "," . $zid . "," . $i . "\" alt=\"" . $stud_id . "," . $zid . "," . $i . "\"></a> "; //if ($i<$zad_brz_array[$zid]) $zadace_ispis .= "<br/>"; } } else { $status--; // Bio uvećan za 1 $icon = $stat_icon[$status]; $title = $stat_tekst[$status]; $zb = $zadace_bodovi[$zid][$i][$stud_id]; $zadace_ispis .= "<a href=\"#\" onclick=\"javascript:openzadaca(event, '" . $stud_id . "', '" . $zid . "', '" . $i . "'); return false;\"><img src=\"images/16x16/" . $icon . ".png\" width=\"16\" height=\"16\" border=\"0\" align=\"center\" title=\"" . $stud_id . "," . $zid . "," . $i . "\" alt=\"" . $stud_id . "," . $zid . "," . $i . "\"> " . $zb . "</a>"; // if ($i<$zad_brz_array[$zid]) $zadace_ispis .= "<br/>"; $bodova += $zb; } } $zadace_ispis .= " </td>\n"; } // FIKSNE KOMPONENTE - ISPIS $fiksne_ispis = ""; foreach ($fiksna_id_array as $fiksna) { $q328 = myquery("select kb.bodovi from komponentebodovi as kb, ponudakursa as pk where kb.student={$stud_id} and kb.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina={$ag} and kb.komponenta={$fiksna}"); if (mysql_num_rows($q328) > 0) { $fbodova = mysql_result($q328, 0, 0); $fiksne_ispis .= "<td id=\"fiksna-{$stud_id}-{$predmet}-{$fiksna}-{$ag}\" ondblclick=\"coolboxopen(this)\">{$fbodova}</td>\n"; $bodova += $fbodova; } else { $fiksne_ispis .= "<td id=\"fiksna-{$stud_id}-{$predmet}-{$fiksna}-{$ag}\" ondblclick=\"coolboxopen(this)\">/</td>\n"; } } // ISPITI - ISPIS $ispiti_ispis = ""; $komponente = $kmax = array(); foreach ($ispit_id_array as $ispit) { $k = $ispit_komponenta[$ispit]; $q330 = myquery("select ocjena from ispitocjene where ispit={$ispit} and student={$stud_id}"); if (mysql_num_rows($q330) > 0) { $ocjena = mysql_result($q330, 0, 0); $ispiti_ispis .= "<td id=\"ispit-{$stud_id}-{$ispit}\" ondblclick=\"coolboxopen(this)\">{$ocjena}</td>\n"; if (!in_array($k, $komponente) || $ocjena > $kmax[$k]) { $kmax[$k] = $ocjena; } } else { $ispiti_ispis .= "<td id=\"ispit-{$stud_id}-{$ispit}\" ondblclick=\"coolboxopen(this)\">/</td>\n"; } if (!in_array($k, $komponente)) { $komponente[] = $k; } } // Prvo trazimo integralne ispite foreach ($komponente as $k) { if ($komponenta_tip[$k] == 2) { // Koje parcijalne ispite obuhvata integralni $dijelovi = explode("+", $komponenta_opcija[$k]); // Racunamo zbir $zbir = 0; $pao = 0; foreach ($dijelovi as $dio) { $zbir += $kmax[$dio]; if ($kmax[$dio] < $komponenta_prolaz[$dio]) { $pao = 1; } } // Eliminisemo parcijalne obuhvacene integralnim if ($kmax[$k] > $zbir || $pao == 1 && $kmax[$k] >= $komponenta_prolaz[$k]) { $bodova += $kmax[$k]; foreach ($dijelovi as $dio) { $kmax[$dio] = 0; } } } } // Sabiremo preostale parcijalne ispite na sumu bodova foreach ($komponente as $k) { if ($komponenta_tip[$k] != 2) { $bodova += $kmax[$k]; } } // KONACNA OCJENA - ISPIS $q350 = myquery("select ocjena from konacna_ocjena where student={$stud_id} and predmet={$predmet} and akademska_godina={$ag}"); if ($privilegija == "super_asistent") { if (mysql_num_rows($q350) > 0) { $ko_ispis = "<td align=\"center\" id=\"ko-{$stud_id}-{$predmet}-{$ag}\">" . mysql_result($q350, 0, 0) . "</td>\n"; } else { $ko_ispis = "<td align=\"center\" id=\"ko-{$stud_id}-{$predmet}-{$ag}\">/</td>\n"; } } else { if (mysql_num_rows($q350) > 0) { $ko_ispis = "<td align=\"center\" id=\"ko-{$stud_id}-{$predmet}-{$ag}\" ondblclick=\"coolboxopen(this)\">" . mysql_result($q350, 0, 0) . "</td>\n"; } else { $ko_ispis = "<td align=\"center\" id=\"ko-{$stud_id}-{$predmet}-{$ag}\" ondblclick=\"coolboxopen(this)\">/</td>\n"; } } ?> <?php echo $prisustvo_ispis; ?> <?php echo $zadace_ispis; ?> <?php echo $fiksne_ispis; ?> <?php echo $ispiti_ispis; ?> <td align="center"><?php print $bodova; /* Procenat zauzima previše prostora po horizontali, a nije toliko interesantan if ($mogucih_bodova!=0 && $mogucih_bodova!=100) { // ?> (<?=procenat($bodova,$mogucih_bodova)?>)<? } */ ?> </td> <?php echo $ko_ispis; ?> </tr><?php } ?> </table> <p><?php if ($kreiranje > 0) { $k = str_replace("&kreiranje=1", "", genuri()); ?> <a href="<?php echo $k; ?> ">Sakrij dugmad za kreiranje zadataka</a><?php } else { ?> <a href="<?php echo genuri(); ?> &kreiranje=1">Prikaži dugmad za kreiranje zadataka</a><?php } ?> * <a href="?sta=saradnik/grupa&id=<?php echo $labgrupa; ?> ">Refresh</a></p> <?php if ($privilegija == "nastavnik") { ?> <p>Vi ste administrator ovog predmeta.</p><?php } else { if ($privilegija == "super_asistent") { ?> <p>Vi ste super-asistent ovog predmeta.</p><?php } } ?> <p> </p> <?php }
function saradnik_student() { global $userid, $user_siteadmin, $conf_ldap_domain; require "lib/manip.php"; // radi ispisa studenta sa predmeta print '<p><a href="index.php?sta=saradnik/intro">Spisak predmeta i grupa</a></p>' . "\n"; // Ulazni parametri $student = intval($_REQUEST['student']); $predmet = intval($_REQUEST['predmet']); $ag = intval($_REQUEST['ag']); // Provjera ulaznih podataka i podaci za naslov // Student $q40 = myquery("select ime, prezime, brindexa, slika from osoba where id={$student}"); if (mysql_num_rows($q40) < 1) { biguglyerror("Nepoznat student"); zamgerlog("nepoznat student {$student}", 3); zamgerlog2("nepoznat student", $student); return; } $ime = mysql_result($q40, 0, 0); $prezime = mysql_result($q40, 0, 1); $brindexa = mysql_result($q40, 0, 2); $slika = mysql_result($q40, 0, 3); $mailprint = ""; $q45 = myquery("SELECT adresa FROM email WHERE osoba={$student} ORDER BY sistemska DESC, id"); while ($r45 = mysql_fetch_row($q45)) { if ($mailprint) { $mailprint .= ", "; } $mailprint .= "<a href=\"mailto:{$r45['0']}\">{$r45['0']}</a>"; } // Predmet $q5 = myquery("select naziv from predmet where id={$predmet}"); if (mysql_num_rows($q5) < 1) { biguglyerror("Nepoznat predmet"); zamgerlog("nepoznat predmet {$predmet}", 3); return; } $nazivpredmeta = mysql_result($q5, 0, 0); $q15 = myquery("SELECT tippredmeta FROM akademska_godina_predmet WHERE akademska_godina={$ag} AND predmet={$predmet}"); $tippredmeta = mysql_result($q15, 0, 0); if ($tippredmeta == 1000) { $q4 = myquery("SELECT id FROM zavrsni WHERE student={$student} AND predmet={$predmet} AND akademska_godina={$ag}"); if (mysql_num_rows($q4) > 0) { $zavrsni = mysql_result($q4, 0, 0); ?> <script language="JavaScript"> location.href='?sta=nastavnik/zavrsni&akcija=zavrsni_stranica&zavrsni=<?php echo $zavrsni; ?> &predmet=<?php echo $predmet; ?> &ag=<?php echo $ag; ?> '; </script> <?php return; } } // Akademska godina $q6 = myquery("select naziv from akademska_godina where id={$ag}"); if (mysql_num_rows($q6) < 1) { biguglyerror("Nepoznata akademska godina"); zamgerlog("nepoznata ag {$ag}", 3); zamgerlog2("nepoznata ag", $ag); return; } $nazivag = mysql_result($q6, 0, 0); // Da li student sluša predmet $q7 = myquery("select pk.id, pk.semestar from student_predmet as sp, ponudakursa as pk, studij as s where sp.student={$student} and sp.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina={$ag} and pk.studij=s.id"); if (mysql_num_rows($q7) < 1) { biguglyerror("Student nije upisan na ovaj predmet"); zamgerlog("student u{$student} ne slusa predmet pp{$predmet} ag{$ag}", 3); zamgerlog2("id studenta i predmeta ne odgovaraju", $student, $predmet, $ag); return; } $ponudakursa = mysql_result($q7, 0, 0); $semestar = mysql_result($q7, 0, 1); // Koji studij student sluša, koji put $q8 = myquery("select s.naziv, ss.semestar, ns.naziv, ss.ponovac from student_studij as ss, studij as s, nacin_studiranja as ns where ss.student={$student} and ss.akademska_godina={$ag} and ss.semestar mod 2 = " . $semestar % 2 . " and ss.studij=s.id and ss.nacin_studiranja=ns.id"); if (mysql_num_rows($q8) < 1) { $q8 = myquery("select s.naziv, ss.semestar, ns.naziv, ss.ponovac from student_studij as ss, studij as s, nacin_studiranja as ns where ss.student={$student} and ss.akademska_godina={$ag} and ss.semestar mod 2 = 1 and ss.studij=s.id and ss.nacin_studiranja=ns.id"); } if (mysql_num_rows($q8) < 1) { $nazivstudija = "Nije upisan na studij!"; $kolpren = $ponovac = $nacin_studiranja = ""; } else { $nazivstudija = mysql_result($q8, 0, 0); if (mysql_result($q8, 0, 1) < $semestar) { $kolpren = ", kolizija"; } else { if (mysql_result($q8, 0, 1) > $semestar) { $kolpren = ", prenio predmet"; } else { $kolpren = ""; } } $semestar = mysql_result($q8, 0, 1); $nacin_studiranja = mysql_result($q8, 0, 2); if (mysql_result($q8, 0, 3) == 1) { $ponovac = ", ponovac"; } else { $ponovac = ""; } } $q9 = myquery("select ag.id, ag.naziv from student_predmet as sp, ponudakursa as pk, akademska_godina as ag where sp.student={$student} and sp.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina<{$ag} and pk.akademska_godina=ag.id order by ag.id"); if (mysql_num_rows($q9) > 0) { $kojiput = "(" . (mysql_num_rows($q9) + 1) . ". put sluša predmet)"; $dosjei = " Pogledajte dosje za: "; $zarez = 0; while ($r9 = mysql_fetch_row($q9)) { if ($zarez == 0) { $zarez = 1; } else { $dosjei .= ", "; } $dosjei .= "<a href=\"?sta=saradnik/student&student={$student}&predmet={$predmet}&ag={$r9['0']}\">{$r9['1']}</a>"; } $dosjei .= "<br />\n"; } else { $kojiput = ""; $dosjei = ""; } // U kojoj je grupi student $q20 = myquery("select l.id, l.naziv from student_labgrupa as sl, labgrupa as l where sl.student={$student} and sl.labgrupa=l.id and l.predmet={$predmet} and l.akademska_godina={$ag} order by l.virtualna"); if (mysql_num_rows($q20) > 0) { $labgrupa = mysql_result($q20, 0, 0); $lgnaziv = mysql_result($q20, 0, 1); } else { $labgrupa = 0; // Nema labgrupa ili nije ni u jednoj } // Provjera prava pristupa if (!$user_siteadmin) { $q10 = myquery("select nivo_pristupa from nastavnik_predmet where nastavnik={$userid} and predmet={$predmet} and akademska_godina={$ag}"); if (mysql_num_rows($q10) < 1) { biguglyerror("Nemate pravo pristupa ovom studentu"); zamgerlog("nastavnik nije na predmetu (pp{$predmet} ag{$ag})", 3); zamgerlog2("nije saradnik na predmetu", $predmet, $ag); return; } $privilegija = mysql_result($q10, 0, 0); // Provjera ogranicenja $q30 = myquery("select o.labgrupa from ogranicenje as o, labgrupa as l, student_labgrupa as sl where o.nastavnik={$userid} and o.labgrupa=l.id and l.predmet={$predmet} and l.akademska_godina={$ag}"); if (mysql_num_rows($q30) > 0) { $nasao = 0; while ($r30 = mysql_fetch_row($q30)) { if ($r30[0] == $labgrupa) { $nasao = 1; break; } } if ($nasao == 0) { biguglyerror("Student je u grupi za koju vam je ograničen pristup"); zamgerlog("ogranicenje na labgrupu g{$labgrupa}", 3); zamgerlog2("ima ogranicenje na labgrupu", intval($labgrupa)); return; } } } // ---- AKCIJE // Akcija: ispis studenta sa predmeta if ($_GET['akcija'] == "ispis" && $user_siteadmin) { ispis_studenta_sa_predmeta($student, $predmet, $ag); zamgerlog("student ispisan sa predmeta (student u{$student} predmet pp{$predmet})", 4); // nivo 4: audit zamgerlog2("student ispisan sa predmeta", $student, $predmet, $ag); nicemessage("Student ispisan sa predmeta."); return; } if ($_POST['akcija'] == "promjena_grupe" && check_csrf_token()) { $novagrupa = intval($_POST['grupa']); $staragrupa = 0; // Da li je student u nekoj grupi i u kojoj? // (Ne smijemo se osloniti na vrijednost varijable $labgrupa jer // to može biti virtualna grupa iz koje ga ne smijemo ispisati) $q53 = myquery("select l.id, l.naziv from student_labgrupa as sl, labgrupa as l where sl.student={$student} and sl.labgrupa=l.id and l.predmet={$predmet} and l.akademska_godina={$ag} and l.virtualna=0"); if (mysql_num_rows($q53) > 0) { $staragrupa = mysql_result($q53, 0, 0); $naziv_stare_grupe = mysql_result($q53, 0, 1); if ($novagrupa == $staragrupa) { nicemessage("Student se već nalazi u grupi {$naziv_stare_grupe}!"); print '<a href="?sta=saradnik/student&student=' . $student . '&predmet=' . $predmet . '&ag=' . $ag . '">Nazad</a>' . "\n"; return; } ispis_studenta_sa_labgrupe($student, $staragrupa); nicemessage("Student ispisan iz grupe {$naziv_stare_grupe}. Podaci o prisustvu su izgubljeni."); } if ($novagrupa > 0) { $q55 = myquery("insert into student_labgrupa set student={$student}, labgrupa={$novagrupa}"); $q57 = myquery("select naziv from labgrupa where id={$novagrupa}"); nicemessage("Student upisan u grupu " . mysql_result($q57, 0, 0) . ". Kreirani su default podaci o prisustvu."); } // Potrebno je updatovati komponentu za prisustvo jer su podaci sada promijenjeni $q4 = myquery("select k.id from tippredmeta_komponenta as tpk,komponenta as k, akademska_godina_predmet as agp where agp.predmet={$predmet} and agp.tippredmeta=tpk.tippredmeta and agp.akademska_godina={$ag} and tpk.komponenta=k.id and k.tipkomponente=3"); while ($r4 = mysql_fetch_row($q4)) { update_komponente($student, $ponudakursa, $r4[0]); } // Pametni logging if ($staragrupa > 0 && $novagrupa > 0) { zamgerlog("student u{$student} prebacen iz grupe g{$staragrupa} u g{$novagrupa}", 2); // 2 = edit zamgerlog2("promijenjena grupa studenta", $student, $novagrupa, 0, $staragrupa); } else { if ($staragrupa > 0) { zamgerlog("student u{$student} ispisan iz grupe g{$staragrupa}", 2); zamgerlog2("student ispisan sa grupe", $student, intval($staragrupa)); } else { zamgerlog("student u{$student} upisan u grupu g{$novagrupa}", 2); zamgerlog2("student upisan u grupu", $student, $novagrupa); } } // Linkovi za dalje print "<p>Gdje želite sada ići?:<br />\n"; if ($staragrupa > 0) { print '- <a href="?sta=saradnik/grupa&id=' . $staragrupa . '">Spisak studenata u grupi ' . mysql_result($q53, 0, 1) . '</a><br />' . "\n"; } else { print '- <a href="?sta=saradnik/grupa&predmet=' . $predmet . '&ag=' . $ag . '">Spisak svih studenata na predmetu</a><br />' . "\n"; } // Ovo je jedini slučaj kad $staragrupa može biti nula if ($novagrupa > 0) { print '- <a href="?sta=saradnik/grupa&id=' . $novagrupa . '">Spisak studenata u grupi ' . mysql_result($q57, 0, 0) . '</a><br />' . "\n"; } print '- <a href="?sta=saradnik/student&student=' . $student . '&predmet=' . $predmet . '&ag=' . $ag . '">Nazad na detalje studenta ' . $ime . ' ' . $prezime . '</a>' . "\n"; return; } if ($_GET['akcija'] == "ponisti_kviz") { $kviz = intval($_REQUEST['kviz']); $q2000 = myquery("DELETE FROM kviz_student WHERE student={$student} AND kviz={$kviz}"); } // --- ISPIS if ($slika != "") { print "<img src=\"?sta=common/slika&osoba={$student}\" align=\"left\" style=\"margin: 10px\">\n"; } // Određujemo username radi slanja poruke $poruka_link = ""; $q59 = myquery("select login from auth where id={$student}"); if (mysql_num_rows($q59) > 0) { $poruka_link = "<br><a href=\"?sta=common/inbox&akcija=compose&primalac=" . mysql_result($q59, 0, 0) . "\">Pošaljite Zamger poruku</a>"; } // Naslov ?> <h1><?php echo $ime; ?> <?php echo $prezime; ?> (<?php echo $brindexa; ?> )</h1> <p>Upisan na (<?php echo $nazivag; ?> ): <b><?php echo $nazivstudija; ?> , <?php echo $semestar; ?> . semestar <?php echo $ponovac; ?> <?php echo $kolpren; ?> <?php echo $kojiput; ?> </b> <br /> <?php echo $dosjei; ?> <b>Email: <?php echo $mailprint; echo $poruka_link; ?> </b></p> <h3>Predmet: <?php echo $nazivpredmeta; ?> <br /> <?php if ($labgrupa > 0) { print "Grupa: <a href=\"?sta=saradnik/grupa&id={$labgrupa}\">{$lgnaziv}</a>"; } else { print "(nije ni u jednoj grupi)"; } ?> </h3> <?php // Promjena grupe $q60 = myquery("select id,naziv from labgrupa where predmet={$predmet} and akademska_godina={$ag} and virtualna=0 order by naziv"); if (mysql_num_rows($q60) > 0) { ?> <?php echo genform("POST"); ?> <input type="hidden" name="akcija" value="promjena_grupe"> <p>Promijenite grupu: <select name="grupa" class="default"><option value="0"<?php echo $nijedna; ?> >-- Nije ni u jednoj grupi --</option> <?php while ($r60 = mysql_fetch_row($q60)) { if ($r60[0] == $labgrupa) { $value = "SELECTED"; } else { $value = ""; } ?> <option value="<?php echo $r60[0]; ?> " <?php echo $value; ?> ><?php echo $r60[1]; ?> </option> <?php } ?> </select> <input type="submit" value=" Promijeni grupu " class="default"> </form> <?php } // PROGRESS BAR // Kod kopiran iz student/predmet - trebalo bi izdvojiti u lib $q30 = myquery("select kb.bodovi, k.maxbodova, k.tipkomponente, k.id from komponentebodovi as kb, komponenta as k where kb.student={$student} and kb.predmet={$ponudakursa} and kb.komponenta=k.id"); $bodova = $mogucih = 0; while ($r30 = mysql_fetch_row($q30)) { $bodova += $r30[0]; if ($r30[2] == 4) { // Tip komponente: zadaće $q35 = myquery("select sum(bodova) from zadaca where predmet={$predmet} and akademska_godina={$ag} and komponenta={$r30['3']}"); $do_sada_zadace = round(mysql_result($q35, 0, 0), 2); // Zbir bodova za zadaće ne može preći ono koliko nosi komponenta if ($do_sada_zadace > $r30[1]) { $mogucih += $r30[1]; } else { $mogucih += $do_sada_zadace; } } else { $mogucih += $r30[1]; } } if ($bodova > $mogucih) { $bodova = $mogucih; } //ne bi se trebalo desiti // boja označava napredak studenta if ($mogucih == 0) { $procent = 0; } else { $procent = intval($bodova / $mogucih * 100); } if ($procent >= 75) { $color = "#00FF00"; } else { if ($procent >= 50) { $color = "#FFFF00"; } else { $color = "#FF0000"; } } $tabela1 = $procent * 2; $tabela2 = 200 - $tabela1; $ispis1 = "<img src=\"images/fnord.gif\" width=\"{$tabela1}\" height=\"10\">"; $ispis2 = "<img src=\"images/fnord.gif\" width=\"{$tabela2}\" height=\"1\"><br/> {$bodova} bodova"; if ($tabela1 > $tabela2) { $ispis1 = "<img src=\"images/fnord.gif\" width=\"{$tabela1}\" height=\"1\"><br/> {$bodova} bodova"; $ispis2 = "<img src=\"images/fnord.gif\" width=\"{$tabela2}\" height=\"10\">"; } ?> <!-- progress bar --> <table border="0"><tr><td align="left"> <p> <table style="border:1px;border-style:solid" width="206" cellpadding="0" cellspacing="2"><tr> <td width="<?php echo $tabela1; ?> " bgcolor="<?php echo $color; ?> "><?php echo $ispis1; ?> </td> <td width="<?php echo $tabela2; ?> " bgcolor="#FFFFFF"><?php echo $ispis2; ?> </td></tr></table> <table width="208" border="0" cellspacing="0" cellpadding="0"><tr> <td width="68">0</td> <td align="center" width="68">50</td> <td align="right" width="69">100</td></tr></table> što je <?php echo $procent; ?> % od trenutno mogućih <?php echo round($mogucih, 2); ?> bodova.</p> </td></tr></table> <!-- end progress bar --> <?php // Nekoliko korisnih operacija za site admina if ($user_siteadmin) { ?> <p><a href="index.php?sta=saradnik/student&student=<?php echo $student; ?> &predmet=<?php echo $predmet; ?> &ag=<?php echo $ag; ?> &akcija=ispis">Ispiši studenta sa predmeta</a> * <a href="index.php?sta=studentska/osobe&akcija=edit&osoba=<?php echo $student; ?> ">Detaljnije o studentu</a> * <a href="index.php?su=<?php echo $student; ?> ">Prijavi se kao student</a></p> <?php } // PRISUSTVO: print ajah_box(); ?> <script language="JavaScript"> // Funkcija koja se poziva klikom na polje u tabeli function prisustvo(student,cas) { if (zamger_ajah_sending) { alert("Slanje u toku. Sačekajte malo."); return false; } var prisutan = invert(student,cas); ajah_start("index.php?c=N&sta=common/ajah&akcija=prisustvo&student="+student+"&cas="+cas+"&prisutan="+prisutan, "invert("+student+","+cas+")"); // U slucaju da ajah ne uspije, ponovo se poziva funkcija invert } // Switchuje DA i NE function invert(student,cas) { var val = document.getElementById("danetekst-"+student+"-"+cas).innerHTML; if (val == "DA") { document.getElementById("dane-"+student+"-"+cas).style.background = "#FFCCCC"; document.getElementById("danetekst-"+student+"-"+cas).innerHTML = "NE"; return 1; } else { document.getElementById("dane-"+student+"-"+cas).style.background="#CCFFCC"; document.getElementById("danetekst-"+student+"-"+cas).innerHTML = "DA"; return 2; } } function openzadaca(student,zadaca,zadatak) { var url='index.php?sta=saradnik/zadaca&student='+student+'&zadaca='+zadaca+'&zadatak='+zadatak; window.open(url,'blah','width=600,height=600,scrollbars=yes'); } function toggleVisibilityObj(ime){ var me = document.getElementById(ime); if (me.style.display=="none"){ me.style.display="inline"; } else { me.style.display="none"; } return false; // da ne bi radio link } </script> <?php // Ispis tablice prisustva za jednu od grupa u kojima je student function prisustvo_ispis($idgrupe, $imegrupe, $komponenta, $student) { if (!preg_match("/\\w/", $imegrupe)) { $imegrupe = "[Bez naziva]"; } $odsustva = 0; $q70 = myquery("select id,UNIX_TIMESTAMP(datum), vrijeme from cas where labgrupa={$idgrupe} and komponenta={$komponenta}"); if (mysql_num_rows($q70) < 1) { return; } // Ne ispisuj grupe u kojima nema registrovanih časova $datumi = $vremena = $statusi = ""; while ($r70 = mysql_fetch_row($q70)) { $datumi .= "<td>" . date("d.m", $r70[1]) . "</td>\n"; list($sati, $minute, $sekunde) = explode(":", $r70[2]); $vremena .= "<td>{$sati}<sup>{$minute}</sup></td>\n"; $q80 = myquery("select prisutan from prisustvo where student={$student} and cas={$r70['0']}"); if (mysql_num_rows($q80) < 1) { $statusi .= "<td bgcolor=\"#FFFFCC\" align=\"center\" id=\"dane-" . $student . "-" . $r70[0] . "\" onclick=\"javascript:prisustvo(" . $student . "," . $r70[0] . ")\"><div id=\"danetekst-" . $student . "-" . $r70[0] . "\"> / </div></td>\n"; } else { if (mysql_result($q80, 0, 0) == 1) { $statusi .= "<td bgcolor=\"#CCFFCC\" align=\"center\" id=\"dane-" . $student . "-" . $r70[0] . "\" onclick=\"javascript:prisustvo(" . $student . "," . $r70[0] . ")\"><div id=\"danetekst-" . $student . "-" . $r70[0] . "\">DA</div></td>\n"; } else { $statusi .= "<td bgcolor=\"#FFCCCC\" align=\"center\" id=\"dane-" . $student . "-" . $r70[0] . "\" onclick=\"javascript:prisustvo(" . $student . "," . $r70[0] . ")\"><div id=\"danetekst-" . $student . "-" . $r70[0] . "\">NE</div></td>\n"; $odsustva++; } } } ?> <b>Prisustvo (<?php echo $imegrupe; ?> ):</b><br/> <table cellspacing="0" cellpadding="2" border="0" id="prisustvo"> <tr> <th>Datum</th> <?php echo $datumi; ?> </tr> <tr> <th>Vrijeme</th> <?php echo $vremena; ?> </tr> <tr> <th>Prisutan</th> <?php echo $statusi; ?> </tr> </table> </p> <?php return $odsustva; } $q40 = myquery("select k.id,k.maxbodova,k.prolaz,k.opcija from komponenta as k, tippredmeta_komponenta as tpk, akademska_godina_predmet as agp\nwhere agp.predmet={$predmet} and agp.tippredmeta=tpk.tippredmeta and agp.akademska_godina={$ag} and tpk.komponenta=k.id and k.tipkomponente=3"); // 3 = prisustvo while ($r40 = mysql_fetch_row($q40)) { $id_komponente = $r40[0]; $max_bodova = $r40[1]; $min_bodova = $r40[2]; $max_izostanaka = $r40[3]; $odsustva = $casova = 0; $q60 = myquery("select l.id,l.naziv from labgrupa as l, student_labgrupa as sl where l.predmet={$predmet} and l.akademska_godina={$ag} and l.id=sl.labgrupa and sl.student={$student}"); while ($r60 = mysql_fetch_row($q60)) { $odsustva += prisustvo_ispis($r60[0], $r60[1], $id_komponente, $student); $q71 = myquery("select count(*) from cas where labgrupa={$r60['0']} and komponenta={$id_komponente}"); $casova += mysql_result($q71, 0, 0); } if ($max_izostanaka == -1) { if ($casova == 0) { $bodovi = 10; } else { $bodovi = $min_bodova + round(($max_bodova - $min_bodova) * (($casova - $odsustva) / $casova), 2); } } else { if ($max_izostanaka == -2) { // Paraproporcionalni sistem TP if ($odsustva <= 2) { $bodovi = $max_bodova; } else { if ($odsustva <= 2 + ($max_bodova - $min_bodova) / 2) { $bodovi = $max_bodova - ($odsustva - 2) * 2; } else { $bodovi = $min_bodova; } } } else { if ($odsustva <= $max_izostanaka) { $bodovi = $max_bodova; } else { $bodovi = $min_bodova; } } } ?> <p>Ukupno na prisustvo: <b><?php echo $bodovi; ?> </b> bodova.</p> <?php } // KVIZOVI $q200 = myquery("SELECT id, naziv, prolaz_bodova FROM kviz WHERE predmet={$predmet} AND akademska_godina={$ag}"); if (mysql_num_rows($q200) > 0) { ?> <b>Kvizovi:</b><br/> <table cellspacing="0" cellpadding="2" border="0" id="kvizovi"> <thead> <tr> <th>Naziv kviza</th> <th>Rezultat</th> <th>Akcije</th> </tr> </thead> <?php while ($r200 = mysql_fetch_row($q200)) { $q210 = myquery("SELECT dovrsen, bodova FROM kviz_student WHERE student={$student} AND kviz={$r200['0']}"); $tekst = ""; if (mysql_num_rows($q210) > 0) { $bodova = mysql_result($q210, 0, 1); if (mysql_result($q210, 0, 0) == 0) { $tekst = "<img src=\"images/16x16/zad_cekaj.png\" width=\"8\" height=\"8\"> Nije završio/la"; } else { if ($bodova < $r200[2]) { $tekst = "<img src=\"images/16x16/brisanje.png\" width=\"8\" height=\"8\"> {$bodova} bodova"; } else { $tekst = "<img src=\"images/16x16/zad_ok.png\" width=\"8\" height=\"8\"> {$bodova} bodova"; } } } ?> <tr> <td><?php echo $r200[1]; ?> </td> <td><?php echo $tekst; ?> </td> <td><?php if ($tekst !== "") { ?> <a href="?sta=saradnik/student&student=<?php echo $student; ?> &predmet=<?php echo $predmet; ?> &ag=<?php echo $ag; ?> &akcija=ponisti_kviz&kviz=<?php echo $r200[0]; ?> ">Poništi kviz</a><?php } ?> </td> </tr> <?php } ?> </table> </p> <?php } // ZADAĆE // Statusne ikone: $stat_icon = array("zad_bug", "zad_preg", "zad_copy", "zad_bug", "zad_preg", "zad_ok"); $stat_tekst = array("Bug u programu", "Pregled u toku", "Zadaća prepisana", "Bug u programu", "Pregled u toku", "Zadaća OK"); ?> <!-- zadace --> <b>Zadaće:</b><br/> <table cellspacing="0" cellpadding="2" border="0" id="zadace"> <thead> <tr> <td> </td> <?php // Zaglavlje tabele - potreban nam je max. broj zadataka u zadaci $q20 = myquery("select zadataka from zadaca where predmet={$predmet} and akademska_godina={$ag} order by zadataka desc limit 1"); if (mysql_num_rows($q20) > 0) { $broj_zadataka = mysql_result($q20, 0, 0); for ($i = 1; $i <= $broj_zadataka; $i++) { ?> <td>Zadatak <?php echo $i; ?> .</td><?php } } ?> <td><b>Ukupno bodova</b></td> </tr> </thead> <tbody> <?php // Tijelo tabele // LEGENDA STATUS POLJA: // 0 - nepoznat status // 1 - nova zadaća // 2 - prepisana // 3 - ne može se kompajlirati // 4 - prošla test, predstoji kontrola // 5 - pregledana /* Ovo se sve moglo kroz SQL rijesiti, ali necu iz razloga: 1. PHP je citljiviji 2. MySQL <4.1 ne podrzava subqueries */ $bodova_sve_zadace = 0; $q21 = myquery("select id,naziv,bodova,zadataka from zadaca where predmet={$predmet} and akademska_godina={$ag} order by komponenta,id"); while ($r21 = mysql_fetch_row($q21)) { $zadaca = $r21[0]; $mogucih += $r21[2]; $zzadataka = $r21[3]; ?> <tr> <th><?php echo $r21[1]; ?> </th> <?php $bodova_zadaca = 0; for ($zadatak = 1; $zadatak <= $broj_zadataka; $zadatak++) { // Ako tekuća zadaća nema toliko zadataka, ispisujemo blank polje if ($zadatak > $zzadataka) { ?> <td> </td><?php continue; } // Uzmi samo rjesenje sa zadnjim IDom $q22 = myquery("select status,bodova,komentar from zadatak where student={$student} and zadaca={$zadaca} and redni_broj={$zadatak} order by id desc limit 1"); if (mysql_num_rows($q22) < 1) { ?> <td> </td><?php } else { $status = mysql_result($q22, 0, 0); $bodova_zadatak = mysql_result($q22, 0, 1); $bodova_zadaca += $bodova_zadatak; if (strlen(mysql_result($q22, 0, 2)) > 2) { $imakomentar = "<img src=\"images/16x16/komentar.png\" width=\"15\" height=\"14\" border=\"0\" title=\"Ima komentar\" alt=\"Ima komentar\" align=\"center\">"; } else { $imakomentar = ""; } ?> <td><a href="javascript:openzadaca('<?php echo $student; ?> ', '<?php echo $zadaca; ?> ', '<?php echo $zadatak; ?> ')"><img src="images/16x16/<?php echo $stat_icon[$status]; ?> .png" width="16" height="16" border="0" align="center" title="<?php echo $stat_tekst[$status]; ?> " alt="<?php echo $stat_tekst[$status]; ?> "> <?php echo $bodova_zadatak; ?> <?php echo $imakomentar; ?> </a></td> <?php } } ?> <td><?php echo $bodova_zadaca; ?> </td> </tr> <?php $bodova_sve_zadace += $bodova_zadaca; } // Ukupno bodova za studenta $bodova += $bodova_sve_zadace; ?> <tr><td colspan="<?php echo $broj_zadataka + 1; ?> " align="right">UKUPNO: </td> <td><?php echo $bodova_sve_zadace; ?> </td></tr> </tbody> </table> <p>Za historiju izmjena kliknite na željeni zadatak. <a href="#" onclick="javascript:window.open('legenda-zadace.html','blah6','width=320,height=130'); return false;">Legenda simbola</a></p> <br/> <!-- end zadace --> <?php // Importujemo kod za coolbox cool_box('ajah_start("index.php?c=N&sta=common/ajah&akcija=izmjena_ispita&idpolja="+zamger_coolbox_origcaller.id+"&vrijednost="+coolboxedit.value, "undo_coolbox()", "zamger_coolbox_origcaller=false");'); ?> <script language="JavaScript"> function undo_coolbox() { var greska = document.getElementById("zamger_ajah-info").innerText || document.getElementById("zamger_ajah-info").textContent; if (!greska.match(/\S/)) greska = "Došlo je do greške. Molimo kontaktirajte administratora."; alert(greska); zamger_coolbox_origcaller.innerHTML = zamger_coolbox_origvalue; zamger_coolbox_origcaller=false; } </script> <?php // FIKSNE KOMPONENTE $q25 = myquery("select k.id, k.gui_naziv from komponenta as k, tippredmeta_komponenta as tpk, akademska_godina_predmet as agp where agp.predmet={$predmet} and agp.tippredmeta=tpk.tippredmeta and agp.akademska_godina={$ag} and tpk.komponenta=k.id and k.tipkomponente=5"); // 5 = fiksna komponenta if (mysql_num_rows($q25) > 0) { ?> <!-- fiksne komponente --> <table cellspacing="0" cellpadding="2" border="0" id="zadace"> <thead> <tr> <td><b>Komponenta ocjene</b></td> <td><b>Bodovi</b></td> <td><b>Dnevnik izmjena</b></td> </tr> </thead> <tbody> <?php } while ($r25 = mysql_fetch_row($q25)) { $komponenta = $r25[0]; $q27 = myquery("select bodovi from komponentebodovi where student={$student} and predmet={$ponudakursa} and komponenta={$komponenta}"); if (mysql_num_rows($q27) < 1) { $ocjenaedit = "/"; } else { $ocjenaedit = mysql_result($q27, 0, 0); } ?> <tr> <td><?php echo $r25[1]; ?> </td> <td id="fiksna-<?php echo $student; ?> -<?php echo $predmet; ?> -<?php echo $komponenta; ?> -<?php echo $ag; ?> " ondblclick="coolboxopen(this)"><?php echo $ocjenaedit; ?> </td> <td><?php if ($privilegija == "nastavnik" || $privilegija == "super_asistent" || $user_siteadmin) { ?> <div id="fiksnalog<?php echo $komponenta; ?> "></div><?php } else { print "/"; } ?> </td> </tr> <?php } if (mysql_num_rows($q25) > 0) { ?> </tbody> </table> <p> </p> <?php } // ISPITI ?> <!-- ispiti --> <b>Ispiti:</b><br/> <?php $q30 = myquery("select i.id, UNIX_TIMESTAMP(i.datum), k.gui_naziv, k.id, k.prolaz from ispit as i, komponenta as k where i.predmet={$predmet} and i.akademska_godina={$ag} and i.komponenta=k.id order by i.datum,i.komponenta"); if (mysql_num_rows($q30) == 0) { print "<p>Nije bilo parcijalnih ispita.</p>"; } else { ?> <table cellspacing="0" cellpadding="2" border="0" id="zadace"> <thead> <tr> <td><b>Tip ispita</b></td> <td><b>Datum ispita</b></td> <td><b>Položio/la?</b></td> <td><b>Bodovi</b></td> <td><b>Dnevnik izmjena</b></td> </tr> </thead> <tbody> <?php } while ($r30 = mysql_fetch_row($q30)) { $ispit = $r30[0]; $q40 = myquery("select ocjena from ispitocjene where ispit={$ispit} and student={$student}"); if (mysql_num_rows($q40) < 1) { $ocjenaedit = "/"; $ispitocjena = "Nije izašao/la"; } else { $ocjenaedit = mysql_result($q40, 0, 0); $ispitocjena = "<b>" . mysql_result($q40, 0, 0) . " bodova</b>"; } /* ?> <p><?=$r30[2]?> (<?=date("d. m. Y",$r30[1])?>): <?=$ispitocjena?> <?*/ ?> <tr> <td><?php echo $r30[2]; ?> </td> <td><?php echo date("d. m. Y", $r30[1]); ?> </td> <td><?php if ($ocjenaedit == "/") { print " "; } else { if ($ocjenaedit >= $r30[4]) { print "<img src=\"images/16x16/zad_ok.png\" width=\"16\" height=\"16\">"; } else { print "<img src=\"images/16x16/brisanje.png\" width=\"16\" height=\"16\">"; } } // najljepše slike ?> </td> <td id="ispit-<?php echo $student; ?> -<?php echo $ispit; ?> " ondblclick="coolboxopen(this)"><?php echo $ocjenaedit; ?> </td> <td><?php if ($privilegija == "nastavnik" || $privilegija == "super_asistent" || $user_siteadmin) { ?> <div id="ispitlog<?php echo $ispit; ?> "></div><?php } else { print "/"; } ?> </td> </tr> <?php /* if ($predmet_admin || $user_siteadmin) { ?> <span id="ispitlink<?=$ispit?>">(<a href="#" onclick="return toggleVisibilityObj('ispitlog<?=$ispit?>');">dnevnik izmjena</a>)</span> (<a href="#" onclick="return toggleVisibilityObj('ispitunos<?=$ispit?>');">upišite rezultat</a>)</p> <p><div id="ispitlog<?=$ispit?>" style="display:none"></div></p> <p><div id="ispitunos<?=$ispit?>" style="display:none"> <table border="0" cellspacing="0" cellpadding="2" height="16"><tr height="16"> <td width="37"> </td> <td align="left">Unesite bodove ili znak "kosa crta" (/):</td> <td width="5"> <br/> </td> <td id="ispit-<?=$student?>-<?=$ispit?>" ondblclick="coolboxopen(this)" width="32" height="32" style="font-size:11px; border:1px solid black"><?=$ocjenaedit?></td> </tr></table> </div></p> <? } else { print "</p>\n"; }*/ } if (mysql_num_rows($q30) > 0) { ?> </tbody></table> <p>Dvokliknite na bodove da promijenite podatak ili upišete novi. Za brisanje rezultata, pobrišite postojeći podatak i pritisnite Enter.</p> <?php } // KONAČNA OCJENA $vrijeme_konacne_ocjene = 0; $q50 = myquery("select ocjena, UNIX_TIMESTAMP(datum), UNIX_TIMESTAMP(datum_u_indeksu) from konacna_ocjena where student={$student} and predmet={$predmet} and akademska_godina={$ag}"); if (mysql_num_rows($q50) > 0) { $konacnaocjena = mysql_result($q50, 0, 0); $vrijeme_konacne_ocjene = mysql_result($q50, 0, 1); $datum_u_indeksu = mysql_result($q50, 0, 2); } else { $konacnaocjena = "/"; } ?> <p> </p> <table cellspacing="0" cellpadding="2" border="0" id="zadace"> <tr> <td> </td> <td>Ocjena:</td> <td>Datum u indeksu:</td> <td>Dnevnik izmjena:</td> </tr> <tr> <td><b>Konačna ocjena:</b></td> <?php if ($privilegija == "nastavnik" || $user_siteadmin) { ?> <td id="ko-<?php echo $student; ?> -<?php echo $predmet; ?> -<?php echo $ag; ?> " ondblclick="coolboxopen(this)"><?php echo $konacnaocjena; ?> </td> <td id="kodatum-<?php echo $student; ?> -<?php echo $predmet; ?> -<?php echo $ag; ?> " ondblclick="coolboxopen(this)"><?php echo date("d. m. Y", $datum_u_indeksu); ?> </td> <td><div id="kolog"></div></td> <?php } else { ?> <td><?php echo $konacnaocjena; ?> </td> <?php } print "</tr></table>\n"; // ************************************** // POPUNA LOGOVA // ************************************** // Ne radimo ništa ako korisnik nema privilegije if ($privilegija != "nastavnik" && $privilegija != "super_asistent" && !$user_siteadmin) { return; } ?> <SCRIPT language="JavaScript"> <?php // Spisak ponuda kursa, za slucaj da nema rezultata $q90 = myquery("select id from ponudakursa where predmet={$predmet} and akademska_godina={$ag}"); $pkovi = array(); while ($r90 = mysql_fetch_row($q90)) { array_push($pkovi, $r90[0]); } // Log za ispite $q100 = myquery("select i.id, UNIX_TIMESTAMP(i.vrijemeobjave) from ispit as i, komponenta as k where i.predmet={$predmet} and i.akademska_godina={$ag} and i.komponenta=k.id order by i.datum,i.komponenta"); while ($r100 = mysql_fetch_row($q100)) { $vrijeme_ispita = $r100[1]; // Utvrdjujemo ocjenu da bismo lakse mogli rekonstruisati izmjene kroz log $q105 = myquery("select ocjena from ispitocjene where ispit={$r100['0']} and student={$student}"); if (mysql_num_rows($q105) < 1) { $ispitocjena = "/"; } else { $ispitocjena = mysql_result($q105, 0, 0); } // Spisak izmjena ocjene $q110 = myquery("select dogadjaj, UNIX_TIMESTAMP(vrijeme), userid from log where \n\tdogadjaj like 'AJAH ispit - upisan novi rezultat % (ispit i{$r100['0']}, student u{$student})' or \n\tdogadjaj like 'AJAH ispit - izbrisan rezultat % (ispit i{$r100['0']}, student u{$student})' or \n\tdogadjaj like 'AJAH ispit - izmjena rezultata % (ispit i{$r100['0']}, student u{$student})' order by id desc"); while ($r110 = mysql_fetch_row($q110)) { $datum = date("d.m.Y. H:i:s", $r110[1]); $q120 = myquery("select ime,prezime from osoba where id=" . $r110[2]); if (mysql_num_rows($q120) > 0) { $korisnik = mysql_result($q120, 0, 0) . " " . mysql_result($q120, 0, 1); } else { $korisnik = "/nepoznat korisnik {$r110['2']}/"; } if (strstr($r110[0], "upisan novi rezultat")) { $rezultat = floatval(substr($r110[0], 34)); if ($rezultat != $ispitocjena) { $rezultat .= " ?"; } $ispitocjena = "/"; ?> document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> upisan rezultat <b><?php echo $rezultat; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML; <?php } else { if (strstr($r110[0], "izbrisan rezultat")) { $rezultat = floatval(substr($r110[0], 31)); if ($ispitocjena != "/") { $rezultat .= " ?"; } else { $ispitocjena = $rezultat; } ?> document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> izbrisan rezultat (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML; <?php } else { if (preg_match("/izmjena rezultata ([\\d\\.]+) u ([\\d\\.]+)/", $r110[0], $matches)) { $starirezultat = floatval($matches[1]); $rezultat = floatval($matches[2]); if ($ispitocjena != $rezultat) { $rezultat .= " ?"; } $ispitocjena = $starirezultat; ?> document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> promijenjen rezultat u <b><?php echo $rezultat; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML; <?php } } } } // Necemo traziti masovne unose ako student nije ni izlazio na ispit if ($ispitocjena == "/") { continue; } // Masovni unosi $q110 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovni rezultati ispita za predmet pp{$predmet}' AND UNIX_TIMESTAMP(vrijeme)>{$r100['1']}-10 ORDER BY vrijeme"); // uzimamo razliku 10 sekundi, jer moze doci do malog kasnjenja prilikom unosa u log if (mysql_num_rows($q110) > 0) { $datum = date("d.m.Y. H:i:s", mysql_result($q110, 0, 0)); $q120 = myquery("select ime,prezime from osoba where id=" . mysql_result($q110, 0, 1)); if (mysql_num_rows($q120) > 0) { $korisnik = mysql_result($q120, 0, 0) . " " . mysql_result($q120, 0, 1); } else { $korisnik = "/nepoznat korisnik " . mysql_result($q110, 0, 1) . "/"; } ?> document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovni rezultati ispita - <b><?php echo $ispitocjena; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML; <?php // Nema pod oznakom predmeta, pokusacemo ponudu kursa } else { foreach ($pkovi as $ponudakursa) { $q110 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovni rezultati ispita za predmet p{$ponudakursa}' AND UNIX_TIMESTAMP(vrijeme)>{$r100['1']}-10"); if (mysql_num_rows($q110) > 0) { $datum = date("d.m.Y. H:i:s", mysql_result($q110, 0, 0)); $q120 = myquery("select ime,prezime from osoba where id=" . mysql_result($q110, 0, 1)); if (mysql_num_rows($q120) > 0) { $korisnik = mysql_result($q120, 0, 0) . " " . mysql_result($q120, 0, 1); } else { $korisnik = "/nepoznat korisnik " . mysql_result($q110, 0, 1) . "/"; } ?> document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovni rezultati ispita - <b><?php echo $ispitocjena; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('ispitlog<?php echo $r100[0]; ?> ').innerHTML; <?php break; } } } } // Log za konacnu ocjenu $bilo = 0; $upit = "\ndogadjaj like 'AJAH ko - dodana ocjena % (predmet pp{$predmet}, student u{$student})' or \ndogadjaj like 'AJAH ko - obrisana ocjena % (predmet pp{$predmet}, student u{$student})' or \ndogadjaj like 'AJAH ko - izmjena ocjene % (predmet pp{$predmet}, student u{$student})' or \ndogadjaj like 'dopisana ocjena % prilikom upisa na studij (predmet pp{$predmet}, student u{$student})' or \ndogadjaj like 'masovno dodana ocjena % (predmet pp{$predmet}, student u{$student})'"; $q150 = myquery("select dogadjaj, UNIX_TIMESTAMP(vrijeme), userid from log where {$upit} order by id desc"); while ($r150 = mysql_fetch_row($q150)) { $bilo = 1; $datum = date("d.m.Y. H:i:s", $r150[1]); $q160 = myquery("select ime,prezime from osoba where id={$r150['2']}"); if (mysql_num_rows($q160) > 0) { $korisnik = mysql_result($q160, 0, 0) . " " . mysql_result($q160, 0, 1); } else { $korisnik = "/nepoznat korisnik {$r150['2']}/"; } if (strstr($r150[0], " - dodana ocjena")) { $rezultat = intval(substr($r150[0], 24)); if ($rezultat != $konacnaocjena) { $rezultat .= " ?"; } $konacnaocjena = "/"; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> dodana ocjena <b><?php echo $rezultat; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php } else { if (strstr($r150[0], "obrisana ocjena")) { $rezultat = intval(substr($r150[0], 26)); if ($konacnaocjena != "/") { $rezultat .= " ?"; } else { $konacnaocjena = $rezultat; } ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> obrisana ocjena (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php } else { if (preg_match("/izmjena ocjene (\\d+) u (\\d+)/", $r150[0], $matches)) { $starirezultat = intval($matches[1]); $rezultat = intval($matches[2]); if ($konacnaocjena != $rezultat) { $rezultat .= " ?"; } $konacnaocjena = $starirezultat; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> promijenjena ocjena u <b><?php echo $rezultat; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php } else { if (strstr($r150[0], "dopisana ocjena")) { $rezultat = intval(substr($r150[0], 16)); if ($konacnaocjena != $rezultat) { $rezultat .= " ?"; } $konacnaocjena = "/"; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> studentska služba dopisala ocjenu <b><?php echo $rezultat; ?> </b> prilikom upisa u sljedeći semestar (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php } else { if (strstr($r150[0], "masovno dodana ocjena")) { $rezultat = intval(substr($r150[0], 22)); if ($konacnaocjena != $rezultat) { $rezultat .= " ?"; } $konacnaocjena = "/"; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovno upisana ocjena <b><?php echo $rezultat; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php } } } } } } /*if (mysql_num_rows($q150)<1) foreach ($pkovi as $ponudakursa) { $q150 = myquery("select dogadjaj, UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj like 'AJAH ko - dodana ocjena % (predmet p$ponudakursa, student u$student)' or dogadjaj like 'AJAH ko - obrisana ocjena % (predmet p$ponudakursa, student u$student)' or dogadjaj like 'AJAH ko - izmjena ocjene % (predmet p$ponudakursa, student u$student)' order by id desc"); while ($r150 = mysql_fetch_row($q150)) { $bilo=1; $datum = date("d.m.Y. H:i:s", $r150[1]); $q160 = myquery("select ime,prezime from osoba where id=$r150[2]"); if (mysql_num_rows($q160)>0) { $korisnik = mysql_result($q160,0,0)." ".mysql_result($q160,0,1); } else { $korisnik = "/nepoznat korisnik $r150[2]/"; } if (strstr($r150[0], "dodana ocjena")) { $rezultat = intval(substr($r150[0], 24)); if ($rezultat != $konacnaocjena) $rezultat .= " ?"; $konacnaocjena = "/"; $vrijeme_konacne_ocjene=$r150[1]; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> dodana ocjena <b><?=$rezultat?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('kolog').innerHTML; <? } else if (strstr($r150[0], "obrisana ocjena")) { $rezultat = intval(substr($r150[0], 26)); if ($konacnaocjena != "/") $rezultat .= " ?"; else $konacnaocjena=$rezultat; $vrijeme_konacne_ocjene=0; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> obrisana ocjena (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('kolog').innerHTML; <? } else if (preg_match("/izmjena ocjene (\d+) u (\d+)/", $r150[0], $matches)) { $starirezultat = intval($matches[1]); $rezultat = intval($matches[2]); if ($konacnaocjena != $rezultat) $rezultat .= " ?"; $konacnaocjena = $starirezultat; $vrijeme_konacne_ocjene=$r150[1]; ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> promijenjena ocjena u <b><?=$rezultat?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('kolog').innerHTML; <? } //print "$r150[0] $r150[1] $r150[2]\n"; } }*/ if (mysql_num_rows($q150) == 0 && $vrijeme_konacne_ocjene > 0) { $bilo = 1; $q170 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovno upisane ocjene na predmet pp{$predmet}' AND ABS(UNIX_TIMESTAMP(vrijeme)-{$vrijeme_konacne_ocjene})<10"); // uzimamo apsolutnu razliku 10 sekundi, jer moze doci do malog kasnjenja prilikom unosa u log if (mysql_num_rows($q170) > 0) { $datum = date("d.m.Y. H:i:s", mysql_result($q170, 0, 0)); $q180 = myquery("select ime,prezime from osoba where id=" . mysql_result($q170, 0, 1)); if (mysql_num_rows($q180) > 0) { $korisnik = mysql_result($q180, 0, 0) . " " . mysql_result($q180, 0, 1); } else { $korisnik = "/nepoznat korisnik " . mysql_result($q170, 0, 1) . "/"; } ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovno unesene ocjene - <b><?php echo $konacnaocjena; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php // Nema pod oznakom predmeta, pokusacemo ponudu kursa } else { foreach ($pkovi as $ponudakursa) { $q170 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovno upisane ocjene na predmet p{$ponudakursa}' AND ABS(UNIX_TIMESTAMP(vrijeme)-" . mysql_result($q50, 0, 1) . ")<10"); // uzimamo apsolutnu razliku 10 sekundi, jer moze doci do malog kasnjenja prilikom unosa u log if (mysql_num_rows($q170) > 0) { $datum = date("d.m.Y. H:i:s", mysql_result($q170, 0, 0)); $q180 = myquery("select ime,prezime from osoba where id=" . mysql_result($q170, 0, 1)); if (mysql_num_rows($q180) > 0) { $korisnik = mysql_result($q180, 0, 0) . " " . mysql_result($q180, 0, 1); } else { $korisnik = "/nepoznat korisnik " . mysql_result($q170, 0, 1) . "/"; } ?> document.getElementById('kolog').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovno unesene ocjene - <b><?php echo $konacnaocjena; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('kolog').innerHTML; <?php } } } } // Ako nema nista u logu, sakrivamo ga if ($bilo == 0) { ?> toggleVisibilityObj('kolink'); <?php } // Log za fiksne komponente // Radimo samo ako ima fiksnih komponenti $q200 = myquery("select k.id from komponenta as k, tippredmeta_komponenta as tpk, akademska_godina_predmet as agp where agp.predmet={$predmet} and agp.tippredmeta=tpk.tippredmeta and agp.akademska_godina={$ag} and tpk.komponenta=k.id and k.tipkomponente=5"); // 5 = fiksna komponenta while ($r200 = mysql_fetch_row($q200)) { $komponenta = $r200[0]; // Utvrdjujemo ocjenu da bismo lakse mogli rekonstruisati izmjene kroz log $q205 = myquery("select bodovi from komponentebodovi where student={$student} and predmet={$ponudakursa} and komponenta={$komponenta}"); if (mysql_num_rows($q205) < 1) { $ispitocjena = "/"; } else { $ispitocjena = mysql_result($q205, 0, 0); } // Izmjene fiksne komponente putem AJAHa $q210 = myquery("select dogadjaj, UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj like 'AJAH fiksna - upisani bodovi % za fiksnu komponentu {$komponenta} (predmet pp{$predmet}, student u{$student})' order by id desc"); while ($r210 = mysql_fetch_row($q210)) { $datum = date("d.m.Y. H:i:s", $r210[1]); $q220 = myquery("select ime,prezime from osoba where id=" . $r210[2]); if (mysql_num_rows($q220) > 0) { $korisnik = mysql_result($q220, 0, 0) . " " . mysql_result($q220, 0, 1); } else { $korisnik = "/nepoznat korisnik {$r210['2']}/"; } $rezultat = floatval(substr($r210[0], 29)); ?> document.getElementById('fiksnalog<?php echo $komponenta; ?> ').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> upisan rezultat <b><?php echo $rezultat; ?> </b> (<?php echo $korisnik; ?> , <?php echo $datum; ?> )<br />' + document.getElementById('fiksnalog<?php echo $komponenta; ?> ').innerHTML; <?php } // Masovni unosi - jednog dana kad bude /* $q110 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovni rezultati ispita za predmet pp$predmet' AND ABS(UNIX_TIMESTAMP(vrijeme)-$r100[1])<10"); // uzimamo apsolutnu razliku 10 sekundi, jer moze doci do malog kasnjenja prilikom unosa u log if (mysql_num_rows($q110)>0) { $datum = date("d.m.Y. H:i:s", mysql_result($q110,0,0)); $q120 = myquery("select ime,prezime from osoba where id=".mysql_result($q110,0,1)); if (mysql_num_rows($q120)>0) { $korisnik = mysql_result($q120,0,0)." ".mysql_result($q120,0,1); } else { $korisnik = "/nepoznat korisnik/"; } ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovni rezultati ispita - <b><?=$ispitocjena?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? // Nema pod oznakom predmeta, pokusacemo ponudu kursa } else foreach ($pkovi as $ponudakursa) { $q110 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovni rezultati ispita za predmet p$ponudakursa' AND ABS(UNIX_TIMESTAMP(vrijeme)-$r100[1])<10"); if (mysql_num_rows($q110)>0) { $datum = date("d.m.Y. H:i:s", mysql_result($q110,0,0)); $q120 = myquery("select ime,prezime from osoba where id=".mysql_result($q110,0,1)); if (mysql_num_rows($q120)>0) { $korisnik = mysql_result($q120,0,0)." ".mysql_result($q120,0,1); } else { $korisnik = "/nepoznat korisnik/"; } ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovni rezultati ispita - <b><?=$ispitocjena?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? } }*/ } /*$q100 = myquery("select i.id, UNIX_TIMESTAMP(i.vrijemeobjave) from ispit as i, komponenta as k where i.predmet=$predmet and i.akademska_godina=$ag and i.komponenta=k.id order by i.datum,i.komponenta"); while ($r100 = mysql_fetch_row($q100)) { // Utvrdjujemo ocjenu da bismo lakse mogli rekonstruisati izmjene kroz log $q105 = myquery("select ocjena from ispitocjene where ispit=$r100[0] and student=$student"); if (mysql_num_rows($q105)<1) $ispitocjena="/"; else $ispitocjena=mysql_result($q105,0,0); // Spisak izmjena ocjene $q110 = myquery("select dogadjaj, UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj like 'AJAH ispit - upisan novi rezultat % (ispit i$r100[0], student u$student)' or dogadjaj like 'AJAH ispit - izbrisan rezultat % (ispit i$r100[0], student u$student)' or dogadjaj like 'AJAH ispit - izmjena rezultata % (ispit i$r100[0], student u$student)' order by id desc"); while ($r110 = mysql_fetch_row($q110)) { $datum = date("d.m.Y. H:i:s", $r110[1]); $q120 = myquery("select ime,prezime from osoba where id=".$r110[2]); if (mysql_num_rows($q120)>0) { $korisnik = mysql_result($q120,0,0)." ".mysql_result($q120,0,1); } else { $korisnik = "/nepoznat korisnik $r110[2]/"; } if (strstr($r110[0], "upisan novi rezultat")) { $rezultat = floatval(substr($r110[0], 34)); if ($rezultat != $ispitocjena) $rezultat .= " ?"; $ispitocjena = "/"; ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> upisan rezultat <b><?=$rezultat?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? } else if (strstr($r110[0], "izbrisan rezultat")) { $rezultat = floatval(substr($r110[0], 31)); if ($ispitocjena != "/") $rezultat .= " ?"; else $ispitocjena=$rezultat; ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> izbrisan rezultat (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? } else if (preg_match("/izmjena rezultata ([\d\.]+) u ([\d\.]+)/", $r110[0], $matches)) { $starirezultat = floatval($matches[1]); $rezultat = floatval($matches[2]); if ($ispitocjena != $rezultat) $rezultat .= " ?"; $ispitocjena = $starirezultat; ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> promijenjen rezultat u <b><?=$rezultat?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? } } // Sakrivamo link na log ako nema ništa u njemu if ($ispitocjena == "/" && mysql_num_rows($q110)<1) { /* ?> toggleVisibilityObj('ispitlink<?=$r100[0]?>'); <?*/ /* } // Necemo traziti masovne unose ako student nije ni izlazio na ispit if ($ispitocjena == "/") continue; // Masovni unosi $q110 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovni rezultati ispita za predmet pp$predmet' AND ABS(UNIX_TIMESTAMP(vrijeme)-$r100[1])<10"); // uzimamo apsolutnu razliku 10 sekundi, jer moze doci do malog kasnjenja prilikom unosa u log if (mysql_num_rows($q110)>0) { $datum = date("d.m.Y. H:i:s", mysql_result($q110,0,0)); $q120 = myquery("select ime,prezime from osoba where id=".mysql_result($q110,0,1)); if (mysql_num_rows($q120)>0) { $korisnik = mysql_result($q120,0,0)." ".mysql_result($q120,0,1); } else { $korisnik = "/nepoznat korisnik ".mysql_result($q110,0,1)."/"; } ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovni rezultati ispita - <b><?=$ispitocjena?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? // Nema pod oznakom predmeta, pokusacemo ponudu kursa } else foreach ($pkovi as $ponudakursa) { $q110 = myquery("select UNIX_TIMESTAMP(vrijeme), userid from log where dogadjaj='masovni rezultati ispita za predmet p$ponudakursa' AND ABS(UNIX_TIMESTAMP(vrijeme)-$r100[1])<10"); if (mysql_num_rows($q110)>0) { $datum = date("d.m.Y. H:i:s", mysql_result($q110,0,0)); $q120 = myquery("select ime,prezime from osoba where id=".mysql_result($q110,0,1)); if (mysql_num_rows($q120)>0) { $korisnik = mysql_result($q120,0,0)." ".mysql_result($q120,0,1); } else { $korisnik = "/nepoznat korisnik ".mysql_result($q110,0,1)."/"; } ?> document.getElementById('ispitlog<?=$r100[0]?>').innerHTML = '<img src="images/16x16/log_edit.png" width="16" height="16" align="center"> masovni rezultati ispita - <b><?=$ispitocjena?></b> (<?=$korisnik?>, <?=$datum?>)<br />' + document.getElementById('ispitlog<?=$r100[0]?>').innerHTML; <? } } }*/ ?> </SCRIPT> <?php }
function izvjestaj_termini_ispita() { global $userid, $user_nastavnik, $user_studentska, $user_siteadmin; ?> <p>Univerzitet u Sarajevu<br/> Elektrotehnički fakultet Sarajevo</p> <p>Datum i vrijeme izvještaja: <?php echo date("d. m. Y. H:i"); ?> </p> <?php // Parametar if (isset($_REQUEST['termin'])) { $termin_id_url = intval($_REQUEST['termin']); } if (isset($_REQUEST['ispit'])) { $ispit = intval($_REQUEST['ispit']); } else { $q8 = myquery("select ispit from ispit_termin where id={$termin_id_url}"); if (mysql_num_rows($q8) < 1) { niceerror("Nepostojeći termin."); return; } $ispit = mysql_result($q8, 0, 0); } $q9 = myquery("select komponenta from ispit where id={$ispit}"); if (mysql_num_rows($q9) < 1) { niceerror("Nepostojeći ispit."); return; } $komp = mysql_result($q9, 0, 0); // Upit za ispit if ($komp <= 4) { // FIXME Oznake komponente <= 4 se koriste za regularne ispite $q10 = myquery("select UNIX_TIMESTAMP(i.datum), k.gui_naziv, i.predmet, i.akademska_godina from ispit as i, komponenta as k where i.id={$ispit} and i.komponenta=k.id"); } else { $q10 = myquery("select UNIX_TIMESTAMP(i.datum), d.naziv, i.predmet, i.akademska_godina from ispit as i, dogadjaj as d where i.id={$ispit} and i.komponenta=d.id"); } $predmet = mysql_result($q10, 0, 2); $ag = mysql_result($q10, 0, 3); $finidatum = date("d. m. Y.", mysql_result($q10, 0, 0)); $naziv = mysql_result($q10, 0, 1); // Dodatna provjera privilegija if (!$user_studentska && !$user_siteadmin) { $q20 = myquery("select nivo_pristupa from nastavnik_predmet where nastavnik={$userid} and predmet={$predmet} and akademska_godina={$ag}"); if (mysql_num_rows($q20) < 1) { biguglyerror("Nemate permisije za pristup ovom izvještaju"); zamgerlog("nije admin predmeta pp{$predmet} godina ag{$ag}", 3); // 3 = error return; } $privilegija = mysql_result($q20, 0, 0); } // Cool editing box if ($privilegija == "nastavnik" || $privilegija == "super_asistent" || $user_siteadmin) { cool_box('ajah_start("index.php?c=N&sta=common/ajah&akcija=izmjena_ispita&idpolja="+zamger_coolbox_origcaller.id+"&vrijednost="+coolboxedit.value, "undo_coolbox()", "zamger_coolbox_origcaller=false");'); ?> <script language="JavaScript"> function undo_coolbox() { var greska = document.getElementById("zamger_ajah-info").innerText || document.getElementById("zamger_ajah-info").textContent; alert(greska); zamger_coolbox_origcaller.innerHTML = zamger_coolbox_origvalue; zamger_coolbox_origcaller=false; } </script> <?php } // Naziv predmeta, akademska godina $q21 = myquery("select naziv from predmet where id={$predmet}"); $q22 = myquery("select naziv from akademska_godina where id={$ag}"); ?> <p> </p> <h3><?php echo $naziv; ?> , <?php echo $finidatum; ?> </h3> <p><?php echo mysql_result($q21, 0, 0); ?> <?php echo mysql_result($q22, 0, 0); ?> </p> <?php print ajah_box(); $imeprezime = $brindexa = array(); $qtermini = myquery("SELECT it.id,UNIX_TIMESTAMP(it.datumvrijeme)\n\t\t\t\t FROM ispit_termin it\n\t\t\t\t\t INNER JOIN ispit i ON i.id = it.ispit\n\t\t\t\t\t WHERE i.id={$ispit}\n\t\t\t\t\t ORDER BY it.datumvrijeme\n\t\t\t\t\t"); $broj_termina = 0; if (isset($_REQUEST['termin'])) { $termin_id_from_url = intval($_REQUEST['termin']); ?> <p><a href="?sta=izvjestaj/termini_ispita&termin=<?php echo $termin_id_from_url; ?> ">Refresh</a></p> <?php } else { ?> <p><a href="?sta=izvjestaj/termini_ispita&ispit=<?php echo $ispit; ?> ">Refresh</a></p> <?php } while ($rtermini = mysql_fetch_row($qtermini)) { $broj_termina++; $id_termina = $rtermini[0]; if (isset($_REQUEST['termin'])) { $termin_id_from_url = intval($_REQUEST['termin']); if ($termin_id_from_url != $id_termina) { continue; } } $datum_termina = date("d. m. Y. ( H:i )", $rtermini[1]); if (isset($_REQUEST['ispit'])) { $ispit = intval($_REQUEST['ispit']); } else { $q8 = myquery("select ispit from ispit_termin where id={$termin_id_url}"); $ispit = mysql_result($q8, 0, 0); } print "Termin {$broj_termina} : <h4 style=\"display:inline\"> {$datum_termina}</h4><br></br>"; $q10 = myquery("select o.id, o.prezime, o.ime, o.brindexa \n\t\t\t\t\tfrom osoba as o, student_predmet as sp, ponudakursa as pk, student_ispit_termin sit, ispit_termin it, ispit i\n\t\t\t\t\twhere \n\t\t\t\t\t\tsp.predmet=pk.id \n\t\t\t\t\t\tand sp.student=o.id\n\t\t\t\t\t\tand sit.student=o.id\n\t\t\t\t\t\tand sit.ispit_termin=it.id\n\t\t\t\t\t\tand it.ispit = i.id\n\t\t\t\t\t\tand pk.predmet={$predmet} \n\t\t\t\t\t\tand pk.akademska_godina={$ag}\n\t\t\t\t\t\tand i.id={$ispit}\n\t\t\t\t\t\tand it.id = {$id_termina}\n\t\t\t\t\t\t"); if (mysql_num_rows($q10) < 1) { print "<p>------------------------------------------------------</p>"; print "<p>Nijedan student nije prijavljen na ovaj termin.</p>"; print "<p>------------------------------------------------------</p>"; continue; } while ($r10 = mysql_fetch_row($q10)) { $imeprezime[$r10[0]] = "{$r10['1']} {$r10['2']}"; $brindexa[$r10[0]] = "{$r10['3']}"; } uasort($imeprezime, "bssort"); // bssort - bosanski jezik // Ima li grupa na predmetu? $q27 = myquery("SELECT count(*) FROM labgrupa WHERE predmet={$predmet} AND akademska_godina={$ag} AND virtualna=0"); if (mysql_result($q27, 0, 0) > 0) { $treba_grupe = true; } else { $treba_grupe = false; } $broj_ispita = 0; $ispit_zaglavlje = ""; $oldkomponenta = 0; $ispit_id_array = array(); $q30 = myquery("select i.id, UNIX_TIMESTAMP(i.datum), k.id, k.kratki_gui_naziv, k.tipkomponente, k.maxbodova, k.prolaz, k.opcija from ispit as i, komponenta as k where i.predmet={$predmet} and i.akademska_godina={$ag} and i.komponenta=k.id order by i.datum, i.komponenta"); $imaintegralni = 0; while ($r30 = mysql_fetch_row($q30)) { $komponenta = $r30[2]; $imeispita = $r30[3]; $tipkomponente = $r30[4]; $ispit_zaglavlje .= "<td align=\"center\">{$imeispita}<br/> " . date("d.m.", $r30[1]) . "</td>\n"; $broj_ispita++; $ispit_id_array[] = $r30[0]; $ispit_komponenta[$r30[0]] = $r30[2]; // Pripremamo podatke o komponentama $komponenta_tip[$r30[2]] = $r30[4]; $komponenta_maxb[$r30[2]] = $r30[5]; $komponenta_prolaz[$r30[2]] = $r30[6]; $komponenta_opcija[$r30[2]] = "{$r30['7']}"; } // Racunamo koliko je bilo moguce ostvariti bodova na predmetu (radi racunanja procenta) $mogucih_bodova = 0; foreach ($komponenta_maxb as $kid => $kmb) { if ($komponenta_tip[$kid] != 2 || $imaintegralni == 1 && $broj_ispita < 2) { // osim ako je to jedini ispit $mogucih_bodova += $kmb; } } // Ostale komponente cemo sabrati nesto kasnije... // Za slucaj da prof odrzi integralni bez parcijalnih if ($imaintegralni == 1 && $broj_ispita < 2) { // $razvdoji_ispite=1; goto // Zaglavlje tabele ispita // no php ne podržava goto :( $broj_ispita = 2; // Ovo ce i dalje biti deformisano, ali nesto manje deformisano nego ranije } // SPISAK KOMPONENTI KOJE NISU ISPITI $ostale_komponente = array(); // 1 = parcijalni ispit, 2 = integralni ispit $q40 = myquery("select k.id, k.kratki_gui_naziv, k.tipkomponente, k.maxbodova from komponenta as k, akademska_godina_predmet as agp, tippredmeta_komponenta as tpk where agp.predmet={$predmet} and agp.tippredmeta=tpk.tippredmeta and tpk.komponenta=k.id and k.tipkomponente!=1 and k.tipkomponente!=2 and agp.akademska_godina={$ag}"); while ($r40 = mysql_fetch_row($q40)) { $mogucih_bodova += $r40[3]; $ostale_komponente[$r40[0]] = $r40[1]; } $zaglavlje1 = $zaglavlje2 = ""; // Dva reda zaglavlja tabele // Ostale komponente foreach ($ostale_komponente as $kid => $knaziv) { $zaglavlje1 .= "<td rowspan=\"2\" align=\"center\">{$knaziv}</td>\n"; } ?> <table border="1" cellspacing="0" cellpadding="2"> <tr><td rowspan="2" align="center">R.br.</td> <td rowspan="2" align="center">Prezime i ime</td> <td rowspan="2" align="center">Br. indexa</td> <?php if ($treba_grupe) { ?> <td rowspan="2" align="center">Grupa</td><?php } ?> <?php echo $zaglavlje1; ?> <td align="center" <?php if ($broj_ispita == 0) { ?> rowspan="2" <?php } else { ?> colspan="<?php echo $broj_ispita; ?> " <?php } ?> >Ispiti</td> <td rowspan="2" align="center"><b>UKUPNO</b></td> <td rowspan="2" align="center">Konačna<br/>ocjena</td> </tr> <tr> <?php echo $zaglavlje2; ?> <?php echo $ispit_zaglavlje; ?> </tr> <?php // ------ SPISAK STUDENATA ------ $idovi = array_keys($imeprezime); // Petlja za ispis studenata $redni_broj = 0; foreach ($imeprezime as $stud_id => $stud_imepr) { if (!in_array($stud_id, $idovi)) { continue; } unset($imeprezime[$stud_id]); // Vise se nece javljati $redni_broj++; ?> <tr> <td><?php echo $redni_broj; ?> .</td> <td><?php echo $stud_imepr; ?> </td> <td><?php echo $brindexa[$stud_id]; ?> </td> <?php if ($treba_grupe) { $q220 = myquery("SELECT l.naziv FROM labgrupa as l, student_labgrupa as sl WHERE l.predmet={$predmet} AND l.akademska_godina={$ag} AND l.virtualna=0 AND l.id=sl.labgrupa AND sl.student={$stud_id}"); if (mysql_num_rows($q220) == 0) { $grupa = " "; } else { $grupa = mysql_result($q220, 0, 0); } ?> <td><?php echo $grupa; ?> </td> <?php } $ispis = ""; $bodova = 0; // Zbir bodova koje je student ostvario // OSTALE KOMPONENTE foreach ($ostale_komponente as $kid => $knaziv) { $q230 = myquery("select kb.bodovi from komponentebodovi as kb, ponudakursa as pk where kb.student={$stud_id} and kb.predmet=pk.id and pk.predmet={$predmet} and pk.akademska_godina={$ag} and kb.komponenta={$kid}"); $obodova = 0; if (mysql_num_rows($q230) > 0) { $obodova = mysql_result($q230, 0, 0); } $ispis .= "<td>{$obodova}</td>"; $bodova += $obodova; } // ISPITI if ($broj_ispita == 0) { $ispis .= "<td> </td>"; } $komponente = $kmax = $kispis = array(); foreach ($ispit_id_array as $ispit) { $k = $ispit_komponenta[$ispit]; $q230 = myquery("select ocjena from ispitocjene where ispit={$ispit} and student={$stud_id}"); if (mysql_num_rows($q230) > 0) { $ocjena = mysql_result($q230, 0, 0); $ispis .= "<td align=\"center\" id=\"ispit-{$stud_id}-{$ispit}\" ondblclick=\"coolboxopen(this)\">{$ocjena}</td>\n"; if (!in_array($k, $komponente) || $ocjena > $kmax[$k]) { $kmax[$k] = $ocjena; $kispis[$k] = "<td align=\"center\" id=\"ispit-{$stud_id}-{$ispit}\" ondblclick=\"coolboxopen(this)\">{$ocjena}</td>\n"; } } else { $ispis .= "<td align=\"center\" id=\"ispit-{$stud_id}-{$ispit}\" ondblclick=\"coolboxopen(this)\">/</td>\n"; if ($kispis[$k] == "") { $kispis[$k] = "<td align=\"center\" id=\"ispit-{$stud_id}-{$ispit}\" ondblclick=\"coolboxopen(this)\">/</td>\n"; } } if (!in_array($k, $komponente)) { $komponente[] = $k; } } // Prvo trazimo integralne ispite foreach ($komponente as $k) { if ($komponenta_tip[$k] == 2) { // Koje parcijalne ispite obuhvata integralni $dijelovi = explode("+", $komponenta_opcija[$k]); // Racunamo zbir $zbir = 0; $pao = 0; foreach ($dijelovi as $dio) { $zbir += $kmax[$dio]; if ($kmax[$dio] < $komponenta_prolaz[$dio]) { $pao = 1; } } // Eliminisemo parcijalne obuhvacene integralnim if ($kmax[$k] > $zbir || $pao == 1 && $kmax[$k] >= $komponenta_prolaz[$k]) { $bodova += $kmax[$k]; foreach ($dijelovi as $dio) { $kmax[$dio] = 0; $kispis[$dio] = ""; } $kispis[$k] = "<td align=\"center\" colspan=\"" . count($dijelovi) . "\">" . $kmax[$k] . "</td>\n"; } else { $kispis[$k] = ""; } } } // Sabiremo preostale parcijalne ispite na sumu bodova foreach ($komponente as $k) { if ($komponenta_tip[$k] != 2) { $bodova += $kmax[$k]; } } // STATISTIKE $topscore[$stud_id] = $bodova; print $ispis; print "<td align=\"center\">{$bodova} (" . procenat($bodova, $mogucih_bodova) . ")</td>\n"; // Konacna ocjena $q508 = myquery("select ocjena from konacna_ocjena where student={$stud_id} and predmet={$predmet} and akademska_godina={$ag}"); if (mysql_num_rows($q508) > 0) { print "<td id=\"ko-{$stud_id}-{$predmet}-{$ag}\" ondblclick=\"coolboxopen(this)\">" . mysql_result($q508, 0, 0) . "</td>\n"; } else { print "<td id=\"ko-{$stud_id}-{$predmet}-{$ag}\" ondblclick=\"coolboxopen(this)\">/</td>\n"; } print "</tr>\n"; } print "</table><p> </p>"; } ?> <?php }