Example #1
0
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%">&nbsp;</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>&nbsp;&nbsp;
		<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>&nbsp;&nbsp;
		<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
		&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
		<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>&nbsp;</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">&nbsp;&nbsp;<b>UKUPNO</b>&nbsp;&nbsp;</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}&nbsp;{$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;
        ?>
.&nbsp;<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>&nbsp;</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>&nbsp;";
                        //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 . "\">&nbsp;" . $zb . "</a>";
                    //				if ($i<$zad_brz_array[$zid]) $zadace_ispis .= "<br/>";
                    $bodova += $zb;
                }
            }
            $zadace_ispis .= "&nbsp;</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("&amp;kreiranje=1", "", genuri());
        ?>
<a href="<?php 
        echo $k;
        ?>
">Sakrij dugmad za kreiranje zadataka</a><?php 
    } else {
        ?>
<a href="<?php 
        echo genuri();
        ?>
&amp;kreiranje=1">Prikaži dugmad za kreiranje zadataka</a><?php 
    }
    ?>
 * <a href="?sta=saradnik/grupa&amp;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>&nbsp;</p>
<?php 
}
Example #2
0
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 = "&nbsp;&nbsp;&nbsp;&nbsp;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>&nbsp;</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>&nbsp;</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>&nbsp;</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>&nbsp;</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 "&nbsp;";
        } 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">&nbsp;</td>
        			<td align="left">Unesite bodove ili znak "kosa crta" (/):</td>
        			<td width="5">&nbsp;<br/>&nbsp;</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>&nbsp;</p>
<table cellspacing="0" cellpadding="2" border="0" id="zadace">
<tr>
	<td>&nbsp;</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 
}
Example #3
0
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>&nbsp;</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 = "&nbsp;";
                } 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>&nbsp;</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>&nbsp;</p>";
    }
    ?>

<?php 
}