1 |
<?php |
2 |
include("inc/global.php"); |
3 |
if (!Auth()) exit; |
4 |
$page = CalcPage($PHP_SELF); |
5 |
$p = $page; |
6 |
if (isparam("wb_p")) $p--; |
7 |
if (isparam("wb_OK")) $p++; |
8 |
if (isparam("wb_h")) $p = $PG_HOME; |
9 |
if (isparam("wb_o")) $p = $PG_OVERVIEW; |
10 |
include("inc/conn.php"); |
11 |
DBOpen(); |
12 |
$del = 0; |
13 |
reset($HTTP_GET_VARS); |
14 |
while ($var = key($HTTP_GET_VARS)) { |
15 |
next($HTTP_GET_VARS); |
16 |
if (!eregi('^del_([0-9]+)$', $var, $match)) continue; |
17 |
$del = $match[1]; |
18 |
} |
19 |
reset($HTTP_POST_VARS); |
20 |
while ($var = key($HTTP_POST_VARS)) { |
21 |
next($HTTP_POST_VARS); |
22 |
if (!eregi('^del_([0-9]+)$', $var, $match)) continue; |
23 |
$del = $match[1]; |
24 |
} |
25 |
if ($del) { |
26 |
DBQuery("DELETE FROM edukacije WHERE (sifra=$del) AND (sif_radnika='$sifra') AND (sif_qualification=2)"); |
27 |
if (!$DBH->errstr && $edit == $del) unset($edit); |
28 |
} |
29 |
$warning = 0; |
30 |
if ($update || $p != $page) { |
31 |
if ($obr_ust || $studij || $st_spreme || $vr_spreme || $dat_od || $dat_do || $zvanje || $uispita || $pispita || $usemestara || $psemestara) { |
32 |
if (!$warning) { |
33 |
if ($dat_od) { |
34 |
$dt = DateCheck($dat_od); |
35 |
if ($dt) $datum_od = ComposeDate($dt); |
36 |
else $warning = 1; |
37 |
} else $warning = 2; |
38 |
} |
39 |
if (!$warning) { |
40 |
if ($dat_do) { |
41 |
$dt = DateCheck($dat_do); |
42 |
if ($dt) $datum_do = ComposeDate($dt); |
43 |
else $warning = 3; |
44 |
} #else $warning = 4; |
45 |
} |
46 |
if (!$warning) { |
47 |
if (!$st_spreme) $warning = 5; |
48 |
} |
49 |
if (!$warning) { |
50 |
if (!$vr_spreme) $warning = 6; |
51 |
} |
52 |
if (!$warning) { |
53 |
if ($uispita == "") $warning = 7; |
54 |
} |
55 |
if (!$warning) { |
56 |
if ($pispita == "") $warning = 8; |
57 |
} |
58 |
if (!$warning) { |
59 |
if ($usemestara == "") $warning = 9; |
60 |
} |
61 |
if (!$warning) { |
62 |
if ($psemestara == "") $warning = 10; |
63 |
} |
64 |
if (!$warning) { |
65 |
$studij = ISO_Win($studij); |
66 |
$zvanje = ISO_Win($zvanje); |
67 |
$sif = DBQuery("SELECT sif_str_spreme FROM strucne_spreme WHERE (language='$language') AND (stupanj='$st_spreme') AND (sif_vrsta_str_spreme=$vr_spreme)"); |
68 |
$sif = $sif[0][0]; |
69 |
if (!$sif) $sif = 0; |
70 |
if ($edit) { |
71 |
DBQuery("UPDATE edukacije SET sif_ustanove=$obr_ust,naziv='$studij',titula='$zvanje',sif_strucna_sprema=$sif,datum_upisa='$datum_od',datum_zavrsetka=".($datum_do?"'$datum_do'":"NULL").",ukupno_ispita=$uispita,polozenih_ispita=$pispita,ukupno_semestara=$usemestara,polozenih_semestara=$psemestara WHERE (sif_radnika='$sifra') AND (sifra=$edit) AND (sif_qualification=2)"); |
72 |
} else { |
73 |
$id = DBQuery("SELECT MAX(sifra) FROM edukacije"); |
74 |
$id = $id[0][0] + 1; |
75 |
DBQuery("INSERT INTO edukacije (sifra,sif_radnika,sif_ustanove,naziv,titula,sif_strucna_sprema,datum_upisa,datum_zavrsetka,ukupno_ispita,polozenih_ispita,ukupno_semestara,polozenih_semestara,sif_qualification) VALUES ($id,'$sifra',$obr_ust,'$studij','$zvanje',$sif,'$datum_od',".($datum_do?"'$datum_do'":"NULL").",$uispita,$pispita,$usemestara,$psemestara,2)"); |
76 |
} |
77 |
} |
78 |
} else if ($edit) |
79 |
DBQuery("DELETE FROM edukacije WHERE (sifra=$edit) AND (sif_radnika='$sifra') AND (sif_qualification=2)"); |
80 |
if ($p != $page && !$warning && !$DBH->errstr) { |
81 |
DBClose(); |
82 |
Header("Location: $pages[$p]".Params($p)); |
83 |
exit; |
84 |
} |
85 |
} |
86 |
if (($new || $update) && !$warning && !$DBH->errstr) { |
87 |
unset($edit, $obr_ust, $studij, $zvanje, $st_spreme, $vr_spreme, $uispita, $pispita, $usemestara, $psemestara); |
88 |
unset($dat_od, $dat_od_d, $dat_od_m, $dat_od_g); |
89 |
unset($dat_do, $dat_do_d, $dat_do_m, $dat_do_g); |
90 |
} |
91 |
include("inc/util.php"); |
92 |
$rows = DBQuery("SELECT sifra,naziv,grad FROM ustanove WHERE (language='$language') AND (naziv||grad <> '') AND (obrazovna)"); |
93 |
$ustanove = array(); |
94 |
for ($i = 0; $i < count($rows); $i++) { |
95 |
list($sif, $naz, $grad) = $rows[$i]; |
96 |
if ($grad) $naz = "$naz, $grad"; |
97 |
array_push($ustanove, array("id" => $sif, |
98 |
"name" => HTML_Escape(Win_ISO($naz)))); |
99 |
} |
100 |
usort($ustanove, "sort_name"); |
101 |
$rows = DBQuery("SELECT DISTINCT stupanj FROM strucne_spreme WHERE (language='$language')"); |
102 |
$sss = array(); |
103 |
for ($i = 0; $i < count($rows); $i++) { |
104 |
list($naz) = $rows[$i]; |
105 |
$naz = Win_ISO($naz); |
106 |
array_push($sss, array("id" => $naz, |
107 |
"name" => HTML_Escape(Win_ISO($naz)))); |
108 |
} |
109 |
usort($sss, "sort_name"); |
110 |
$rows = DBQuery("SELECT sifra,opis FROM vrsta_strucne_spreme WHERE (language='$language') AND (opis<>'')"); |
111 |
$vss = array(); |
112 |
for ($i = 0; $i < count($rows); $i++) { |
113 |
list($sif, $naz) = $rows[$i]; |
114 |
array_push($vss, array("id" => $sif, |
115 |
"name" => HTML_Escape(Win_ISO($naz)))); |
116 |
} |
117 |
usort($vss, "sort_name"); |
118 |
$rows = DBQuery("SELECT edukacije.sifra,sif_ustanove,naziv,titula,stupanj,sif_vrsta_str_spreme,datum_upisa,datum_zavrsetka,ukupno_ispita,polozenih_ispita,ukupno_semestara,polozenih_semestara FROM edukacije,strucne_spreme WHERE (sif_radnika='$sifra') AND (sif_qualification=2) AND (strucne_spreme.sif_str_spreme=edukacije.sif_strucna_sprema) ORDER BY datum_upisa"); |
119 |
$vars = array(); |
120 |
$fnd = false; |
121 |
for ($i = 0; $i < count($rows); $i++) { |
122 |
list($id, $ust, $sm, $zv, $st, $vr, $od, $do, $ui, $pi, $us, $ps) = $rows[$i]; |
123 |
$od = ParseDate($od); |
124 |
$do = ParseDate($do); |
125 |
$ust2 = ""; |
126 |
for ($j = 0; $j < count($ustanove); $j++) { |
127 |
if ($ustanove[$j]["id"] == $ust) { |
128 |
$ust2 = $ustanove[$j]["name"]; |
129 |
break; |
130 |
} |
131 |
} |
132 |
$vr2 = ""; |
133 |
for ($j = 0; $j < count($vss); $j++) { |
134 |
if ($vss[$j]["id"] == $vr) { |
135 |
$vr2 = $vss[$j]["name"]; |
136 |
break; |
137 |
} |
138 |
} |
139 |
$sm = HTML_Escape(Win_ISO($sm)); |
140 |
$zv = HTML_Escape(Win_ISO($zv)); |
141 |
$st = HTML_Escape(Win_ISO($st)); |
142 |
$ust2 = nl2br($ust2); |
143 |
$sm2 = nl2br($sm); |
144 |
$zv2 = nl2br($zv); |
145 |
$st2 = nl2br($st); |
146 |
$vr2 = nl2br($vr2); |
147 |
nepoznato($ust2); |
148 |
nepoznato($sm2); |
149 |
nepoznato($zv2); |
150 |
nepoznato($st2); |
151 |
nepoznato($vr2); |
152 |
array_push($vars, array( |
153 |
"id" => $id, |
154 |
"link" => $PHP_SELF.Params($page, array("edit" => $id)), |
155 |
"ustanova" => $ust2, |
156 |
"studij" => $sm2, |
157 |
"zvanje" => $zv2, |
158 |
"sss" => $st2, |
159 |
"vss" => $vr2, |
160 |
"od_d" => $od["mday"], "od_m" => $od["mon"], "od_g" => $od["year"], |
161 |
"do_d" => $do["mday"], "do_m" => $do["mon"], "do_g" => $do["year"], |
162 |
"uispita" => $ui, "pispita" => $pi, |
163 |
"usemestara" => $us, "psemestara" => $ps |
164 |
)); |
165 |
if ($edit && $edit == $id) { |
166 |
if (!$warning) { |
167 |
$obr_ust = $ust; |
168 |
$studij = $sm; |
169 |
$zvanje = $zv; |
170 |
$st_spreme = $st; |
171 |
$vr_spreme = $vr; |
172 |
list($dat_od_d, $dat_od_m, $dat_od_g) = |
173 |
array($od["mday"], $od["mon"], $od["year"]); |
174 |
list($dat_do_d, $dat_do_m, $dat_do_g) = |
175 |
array($do["mday"], $do["mon"], $do["year"]); |
176 |
$uispita = $ui; |
177 |
$pispita = $pi; |
178 |
$usemestara = $us; |
179 |
$psemestara = $ps; |
180 |
} |
181 |
$fnd = true; |
182 |
} |
183 |
} |
184 |
if (!$fnd) unset($edit); |
185 |
DBClose(); |
186 |
$tpl = new MySmarty($page, $edit ? array("edit" => $edit) : array()); |
187 |
$tpl->assign("vars", $vars); |
188 |
$tpl->assign("edit", $edit); |
189 |
$tpl->assign("ou", $ustanove); |
190 |
$tpl->assign("sss", $sss); |
191 |
$tpl->assign("vss", $vss); |
192 |
$tpl->assign("obr_ust", $obr_ust); |
193 |
$tpl->assign("studij", $studij); |
194 |
$tpl->assign("zvanje", $zvanje); |
195 |
$tpl->assign("st_spreme", $st_spreme); |
196 |
$tpl->assign("vr_spreme", $vr_spreme); |
197 |
$tpl->assign("uispita", $uispita); |
198 |
$tpl->assign("pispita", $pispita); |
199 |
$tpl->assign("usemestara", $usemestara); |
200 |
$tpl->assign("psemestara", $psemestara); |
201 |
if ($dat_od_d && $dat_od_m && $dat_od_g) { |
202 |
$tpl->assign("dat_od_d", $dat_od_d); |
203 |
$tpl->assign("dat_od_m", $dat_od_m); |
204 |
$tpl->assign("dat_od_g", $dat_od_g); |
205 |
} else $tpl->assign("dat_od", $dat_od); |
206 |
if ($dat_do_d && $dat_do_m && $dat_do_g) { |
207 |
$tpl->assign("dat_do_d", $dat_do_d); |
208 |
$tpl->assign("dat_do_m", $dat_do_m); |
209 |
$tpl->assign("dat_do_g", $dat_do_g); |
210 |
} else $tpl->assign("dat_do", $dat_do); |
211 |
$tpl->assign("warning", $warning); |
212 |
$tpl->show(); |
213 |
?> |