reposiciones_autorizar.php 54 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054
  1. <?php
  2. require_once 'class/mailer.php';
  3. require_once 'class/c_login.php';
  4. if (!isset($_SESSION['user'])){
  5. die(header('Location: index.php'));
  6. }
  7. //$user = unserialize($_SESSION['user']);
  8. $user = Login::get_user();
  9. $user->access();
  10. //echo $user;
  11. /*print_r($user);
  12. print_r($user->user["id"]);
  13. echo "****|";
  14. print_r($user->acceso);//null sin permisos, w o r
  15. echo "|****|";
  16. print_r($user->profesor);
  17. echo "|****|";
  18. print_r($user->facultad["facultad_id"]);
  19. exit();*/
  20. //profesor, admin, rol, facultad
  21. if ($user->acceso === null && !$user->admin){
  22. die(header('Location: index.php'));
  23. exit();
  24. }
  25. $supervisor = false;
  26. $coordinador = false;
  27. if($user->rol["rol_id"]==7 || $user->rol["rol_id"]==8){
  28. $supervisor = true;
  29. }
  30. if($user->rol["rol_id"]==9 || $user->rol["rol_id"]==8){
  31. $coordinador = true;
  32. }
  33. //$user->print_to_log('Reposiciones');
  34. //$write = $user->admin || in_array($user->acceso, ['w']);
  35. $write = true; //
  36. function duracionMinutos($fechahora_i, $fechahora_f){
  37. return round((strtotime($fechahora_f) - strtotime($fechahora_i)) / 60,2);
  38. }
  39. if($user->periodo_id!= ""){
  40. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo_id])['esta_en_periodo'];
  41. $profesores_rs = array();
  42. $tab_inicial = 1;
  43. if(!$supervisor){
  44. $fac_id = $user->facultad["facultad_id"];
  45. $carrera_rs = $db->query('SELECT * FROM fs_profesor_facultad(:fac, :periodo)', [':fac'=>$fac_id, ':periodo' => $user->periodo_id]);
  46. }else{
  47. $carrera_rs = $db->query('SELECT * FROM fs_profesor_facultad(NULL, :periodo)', [ ':periodo' => $user->periodo_id]);
  48. }
  49. $salones_rs = $db->query('SELECT * from salon_view where es_salon is true');
  50. //Periodo
  51. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo_id]);
  52. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  53. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  54. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  55. else{
  56. $dias = 3;
  57. if( intval(date("w")) >=3 && intval(date("w"))<=5 )//Mie a Vie
  58. $dias+=3;
  59. else if( intval(date("w")) ==6 )//Sab
  60. $dias+=2;
  61. else if( intval(date("w")) ==0 )//Do
  62. $dias+=1;
  63. $fecha_man = date("d/m/Y", strtotime("+".$dias." day"));
  64. }
  65. // Fechas filtro
  66. if(isset($_POST["fecha_inicial"]))
  67. $fecha_ini = $_POST["fecha_inicial"];
  68. else
  69. $fecha_ini = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  70. if(isset($_POST["fecha_final"]))
  71. $fecha_fin = $_POST["fecha_final"];
  72. else
  73. $fecha_fin = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"]));
  74. //Reposiciones
  75. $repEdo_rs = $db->query('SELECT * FROM fs_estado_reposicion' );
  76. $repoParams = array();
  77. $asigParams = array();
  78. $query = "";
  79. if($user->rol["rol_id"] == 9){//es coordinador
  80. $query .= ":facultad, ";
  81. $repoParams[":facultad"] = $user->facultad["facultad_id"];
  82. }else{//supervisor
  83. $query .= "NULL, ";
  84. }
  85. if(isset($_POST["prof"]) ){
  86. $query .= ":prof,";
  87. $profesor = trim($_POST["prof"]);//limpia texto
  88. $repoParams[":prof"] = $profesor;
  89. }else{
  90. $query .= "NULL,";
  91. }
  92. $query .= ":f_ini, :f_fin, ";
  93. $queryAsig = ":f_ini, :f_fin,";
  94. $date = DateTime::createFromFormat('d/m/Y', $fecha_ini);
  95. $fecha_ini_db = $date->format('Y-m-d');
  96. $date = DateTime::createFromFormat('d/m/Y', $fecha_fin);
  97. $fecha_fin_db = $date->format('Y-m-d');
  98. $repoParams[":f_ini"] = $fecha_ini_db;
  99. $repoParams[":f_fin"] = $fecha_fin_db;
  100. $repoParams[":edo"] = 1;//se sobreescribe
  101. $asigParams[":f_ini"] = $fecha_ini_db;
  102. $asigParams[":f_fin"] = $fecha_fin_db;
  103. }
  104. ?>
  105. <!DOCTYPE html>
  106. <html lang="en">
  107. <head>
  108. <title>Reposiciones autorizar | <?= $user->facultad['facultad'] ?? 'General' ?></title>
  109. <meta charset="utf-8">
  110. <meta http-equiv="content-type" content="text/plain; charset=UTF-8" />
  111. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  112. <?php
  113. include 'import/html_css_files.php';
  114. ?>
  115. <script src="js/scrollables.js" defer></script>
  116. <script>
  117. const write = <?= $write ? 'true' : 'false' ?>;
  118. </script>
  119. <style>
  120. .wizard { height: 20px; width: 80%; background: #D0D0D0; }
  121. .wizard.full { background: #D0D0D0; }
  122. .wizard.active > div:first-child { background: #00A6CE; }
  123. .wizard.active > div:last-child { width: 0px; height: 0px; border-style: solid; border-width: 10px 0 10px 6px; border-color: transparent transparent transparent #00a6ce; transform: rotate(0deg); }
  124. </style>
  125. <script src="js/jquery.min.js"></script>
  126. <script src="js/bootstrap/popper.min.js"></script>
  127. <script src="js/bootstrap/bootstrap.min.js"></script>
  128. <script src="js/jquery-ui.js"></script>
  129. <script src="js/datepicker-es.js"></script>
  130. <script src="js/messages.js"></script>
  131. </head>
  132. <!-- -->
  133. <body style="display: block;">
  134. <?php
  135. include('include/constantes.php');
  136. include("import/html_header.php");
  137. html_header("Reposiciones de clase", "Sistema de gestión de checador");
  138. ?>
  139. <?= "<!-- $user -->" ?>
  140. <main class="container content marco content-margin" id="local-app">
  141. <section id="message"></section>
  142. <?php require('import/periodo.php') ?>
  143. <?php if($user->periodo_id!= ""){ ?>
  144. <form action="reposiciones_autorizar.php" id="asistencia" method="post" onsubmit="return validaFechas()">
  145. <div class="form-box">
  146. <input type="hidden" name="facultad" value="5">
  147. <div class="form-group row">
  148. <label for="filtro_inicial" class="col-4 col-form-label">Fecha inicial</label>
  149. <div class="col-8 col-sm-4">
  150. <input id="filtro_inicial" name="fecha_inicial" type="text" class="form-control date-picker-filtro" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="" value="<?php echo $fecha_ini;?>">
  151. <div class="invalid-feedback">No es una fecha válida.</div>
  152. </div>
  153. </div>
  154. <div class="form-group row">
  155. <label for="filtro_final" class="col-4 col-form-label">Fecha final</label>
  156. <div class="col-8 col-sm-4">
  157. <input id="filtro_final" name="fecha_final" type="text" class="form-control date-picker-filtro" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="" value="<?php echo $fecha_fin;?>">
  158. <div class="invalid-feedback">El rango de fechas no es válido.</div>
  159. </div>
  160. </div>
  161. <div class="form-group row">
  162. <label class="col-4 col-form-label" for="prof">Profesor</label>
  163. <div class="col-8 col-sm-4">
  164. <input type="text" name="prof" id="prof" class="form-control" placeholder="Profesor" value="<?php if(isset($profesor)) echo $profesor; ?>">
  165. </div>
  166. </div>
  167. </div>
  168. <div class="form-group row justify-content-center">
  169. <button type="submit" class="btn btn-outline-primary mr-2" id="btn-buscar"><span class="ing-buscar ing-fw"></span> Buscar</button>
  170. <button type="button" class="btn btn-outline-danger" onclick="window.location.href = window.location.href"><span class="ing-borrar ing-fw"></span> Limpiar</button>
  171. </div>
  172. <!--<p class="text-right">
  173. <button class="btn btn-secondary" id="exportar"><span class="ing-descargar"></span>Descargar xls</button>
  174. </p>-->
  175. </form>
  176. <ul class="nav nav-tabs d-print-none mb-4" id="myTab" role="tablist">
  177. <li class="nav-item">
  178. <a class="nav-link" id="tab1-tab" data-toggle="tab" href="#tab1" role="tab" aria-controls="calendario" aria-selected="true">Nuevas reposiciones</a>
  179. </li>
  180. <li class="nav-item">
  181. <a class="nav-link" id="tab2-tab" data-toggle="tab" href="#tab2" role="tab" aria-controls="lista" aria-selected="false">Aprobadas por Facultad</a>
  182. </li>
  183. <li class="nav-item">
  184. <a class="nav-link" id="tab3-tab" data-toggle="tab" href="#tab3" role="tab" aria-controls="lista" aria-selected="false">Autorizadas por Vicerrectoría</a>
  185. </li>
  186. <li class="nav-item">
  187. <a class="nav-link" id="tab4-tab" data-toggle="tab" href="#tab4" role="tab" aria-controls="lista" aria-selected="false">Declinadas</a>
  188. </li>
  189. </ul>
  190. <div class="tab-content" id="TabContent">
  191. <?php
  192. $i=1;
  193. foreach($repEdo_rs as $redo){ ?>
  194. <div class="tab-pane fade" id="tab<?php echo $i;?>" role="tabpanel" aria-labelledby="tab<?php echo $i;?>-tab">
  195. <?php
  196. $tablaArr = [];
  197. $repoParams[":edo"]=$redo["estado_reposicion_id"];
  198. $asigParams[":edo"]=$redo["estado_reposicion_id"];
  199. if($user->rol["rol_id"] == 7){//es supervisor
  200. $repoParams[":sup"] = $user->user["id"];
  201. $reposiciones_rs = $db->query('SELECT * FROM fs_reposicion_solicitud(NULL, '.$query.':edo, 0, NULL, :sup) ', $repoParams );
  202. }else{
  203. $reposiciones_rs = $db->query('SELECT * FROM fs_reposicion_solicitud(NULL, '.$query.':edo, 0, NULL) ', $repoParams );
  204. }
  205. foreach($reposiciones_rs as $repo){
  206. $tablaArr[] = array("id"=>$repo["reposicion_solicitud_id"], "estado"=>$repo["estado_reposicion_id"], "tipo"=>($repo["es_reposicion"]==true?1:2),
  207. "profesor_clave"=>$repo["profesor_clave"], "profesor_nombre"=>$repo["profesor_nombre"], "materia_nombre"=>$repo["materia_nombre"], "horario_grupo"=>$repo["horario_grupo"],
  208. "fecha_falta"=>$repo["fecha_clase"], "fecha_nueva"=>$repo["fecha_nueva"], "hora_original"=> $repo["horario_hora"], "hora_nueva"=>$repo["hora_nueva"], "hora_nueva_fin"=>$repo["hora_nueva_fin"],
  209. "salon_id"=>$repo["salon_id"], "salon_array"=>$repo["salon_array"]);
  210. }
  211. if($user->rol["rol_id"] == 7){//es supervisor
  212. $asigParams[":sup"] = $user->user["id"];
  213. $asignaciones_rs = $db->query('SELECT * FROM fs_asignacion_solicitud(NULL, '.$queryAsig.' :sup, :edo) ', $asigParams );
  214. }else{
  215. $asignaciones_rs = $db->query('SELECT * FROM fs_asignacion_solicitud(NULL, '.$queryAsig.' NULL, :edo) ', $asigParams );
  216. }
  217. foreach($asignaciones_rs as $asig){
  218. $tablaArr[] = array("id"=>$asig["asignacion_solicitud_id"], "estado"=>$asig["estado_reposicion_id"], "tipo"=>3,
  219. "profesor_clave"=>$asig["profesor_clave"], "profesor_nombre"=>$asig["profesor_nombre"], "materia_nombre"=>"", "horario_grupo"=>"",
  220. "fecha_falta"=>"", "fecha_nueva"=>$asig["fecha_nueva"], "hora_original"=>"", "hora_nueva"=>$asig["hora_nueva"], "hora_nueva_fin"=>$asig["hora_nueva_fin"],
  221. "salon_id"=>$asig["salon_id"], "salon_array"=>$asig["salon_array"]);
  222. }
  223. if(count($tablaArr)>0){
  224. //ordena $tablaArr por fecha_repo
  225. usort($tablaArr, function($a, $b) {
  226. return strtotime($a['fecha_nueva']) - strtotime($b['fecha_nueva']);
  227. });
  228. }else{
  229. echo "No hay reposiciones en este estado";
  230. }
  231. ?>
  232. <h4 class="mb-4" <?php echo "style='color:".$redo["estado_color"]."'";?> > <?php echo $redo["estado_nombre"]; ?> </h4>
  233. <table class="table table-sm table-striped table-white">
  234. <thead class="thead-dark">
  235. <tr>
  236. <th>Estado</th>
  237. <th>Tipo</th>
  238. <th>Profesor/Materia</th>
  239. <th style="width:160px">Fecha falta</th>
  240. <th style="width:160px">Fecha reposición</th>
  241. <th>Salón</th>
  242. <?php if($write){ ?><th>Acciones</th><?php } ?>
  243. </tr>
  244. </thead>
  245. <tbody>
  246. <?php
  247. if(isset($tablaArr)){
  248. foreach($tablaArr as $reposicion){
  249. ?>
  250. <tr data-id="<?php echo $reposicion["id"]; ?>" data-edo="<?php echo $reposicion["estado"];?>" id="id<?php echo $reposicion["id"]; ?>">
  251. <td class="align-middle">
  252. <?php if($reposicion["estado"]<3){ ?>
  253. <div class="wizard <?php if(intval($reposicion["estado"])==2) echo "active";?> d-flex mx-auto">
  254. <div class="w-50 h-100"></div>
  255. <div class=""></div>
  256. </div>
  257. <?php } else if($reposicion["estado"]==3){?>
  258. <div class="text-success text-center pt-1">
  259. <span class="ing-autorizar ing-lg"></span>
  260. </div>
  261. <?php } else {?>
  262. <div class="text-danger text-center pt-1">
  263. <span class="ing-negar ing-lg"></span>
  264. </div>
  265. <?php } ?>
  266. </td>
  267. <td class="align-middle">
  268. <?php switch($reposicion["tipo"]){
  269. case 1: echo "Resposición"; break;
  270. case 2: echo "Cambio"; break;
  271. case 3: echo "Asignación"; break;
  272. }?>
  273. </td>
  274. <td><?php
  275. echo $reposicion["profesor_clave"]." - ".$reposicion["profesor_nombre"];
  276. ?>
  277. <br>
  278. <small>
  279. <?php echo $reposicion["materia_nombre"]; ?>
  280. <?php
  281. if($reposicion["horario_grupo"]!="")
  282. echo "(".$reposicion["horario_grupo"].")";
  283. ?>
  284. </small>
  285. </td>
  286. <td class="text-center align-middle text-nowrap"><?php
  287. if($reposicion["fecha_falta"]!=""){
  288. $fechaI = date("d/m/Y", strtotime($reposicion["fecha_falta"]));
  289. echo $fechaI."<br>".substr($reposicion["hora_original"],0, 5);
  290. }else{
  291. echo " - ";
  292. }
  293. ?>
  294. </td>
  295. <td class="text-center align-middle text-nowrap"><?php
  296. $fechaF = date("d/m/Y", strtotime($reposicion["fecha_nueva"]));
  297. echo $fechaF."<br>".substr($reposicion["hora_nueva"],0, 5)." a ".substr($reposicion["hora_nueva_fin"],0, 5);
  298. ?>
  299. </td>
  300. <td class="text-center align-middle"><?php
  301. if($reposicion["salon_id"] != ""){
  302. $salon_json = json_decode($reposicion["salon_array"], true);
  303. echo $salon_json[count($salon_json)-1];
  304. }else
  305. echo "Pendiente";
  306. ?>
  307. </td>
  308. <?php if($write){ ?>
  309. <td class="text-center align-middle icono-acciones text-nowrap">
  310. <?php if (duracionMinutos($reposicion["fecha_nueva"], date("Y-m-d H:i:00")) < 0){ ?>
  311. <?php //no se cumple la fecha de la reposicion, es jefe de carrera
  312. if((!$user->jefe_carrera || $user->admin || !$coordinador) && $reposicion["estado"] == 1){?>
  313. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-estado="2" data-tipo="<?php echo $reposicion["tipo"];?>" title="Aprobar"><?php echo $ICO["ver"];?></a>
  314. <?php } //no se cumple la fecha de la reposicion, no es jefe de carrera
  315. else if(($supervisor || $user->admin) && $reposicion["estado"] == 2){?>
  316. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-estado="3" data-tipo="<?php echo $reposicion["tipo"];?>" title="Autorizar" ><?php echo $ICO["ver"];?></a>
  317. <?php } else { ?>
  318. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-estado="1" data-tipo="<?php echo $reposicion["tipo"];?>" title="Ver detalle"><?php echo $ICO["ver"];?></a>
  319. <?php } ?>
  320. <?php
  321. }else{ //fecha ya pasó?>
  322. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-estado="1" data-tipo="<?php echo $reposicion["tipo"];?>" title="Ver detalle"><span class="text-danger"><?php echo $ICO["ver"];?></span></a>
  323. <?php } ?>
  324. <?php
  325. if($reposicion["estado"]<4){
  326. if(
  327. (($user->jefe_carrera || $user->admin || $coordinador) && $reposicion["estado"] == 1)/* nueva */
  328. || (($user->admin || $coordinador || $supervisor) && $reposicion["estado"] == 2)/* aprobado facultad */
  329. ){
  330. ?>
  331. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Cancelar"><span class="text-danger"><?php echo $ICO["cancelar"];?></span></a>
  332. <?php }
  333. } //estado
  334. ?>
  335. </td>
  336. <?php }//edición ?>
  337. </tr>
  338. <?php
  339. }//foreach
  340. }//if ?>
  341. </tbody>
  342. </table>
  343. </div>
  344. <?php
  345. $i++;
  346. } ?>
  347. </div>
  348. <!-- Modal -->
  349. <div class="modal fade" id="modal_aprobar" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  350. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  351. <div class="modal-content">
  352. <div class="modal-header">
  353. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Aprobar Reposición</span>
  354. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  355. <span aria-hidden="true">&times;</span>
  356. </button></h4>
  357. </div>
  358. <div class="modal-body">
  359. <form action="./action/reposicion_autoriza.php" method="post" id="formaModal">
  360. <input type="hidden" name="id" id="id">
  361. <input type="hidden" name="edo" id="edo" value="">
  362. <input type="hidden" name="tipo" id="tipo" value="">
  363. <div class="row">
  364. <div class="col-6 col-sm-4 barra-right text-right">
  365. <p class="font-weight-bold">Profesor</p>
  366. </div>
  367. <div class="col-6">
  368. <p class="rep-prof"></p>
  369. </div>
  370. </div>
  371. <div class="row">
  372. <div class="col-6 col-sm-4 barra-right text-right">
  373. <p class="font-weight-bold">Dependencia</p>
  374. </div>
  375. <div class="col-6">
  376. <p class="rep-fac"></p>
  377. </div>
  378. </div>
  379. <div class="row">
  380. <div class="col-6 col-sm-4 barra-right text-right">
  381. <p class="font-weight-bold">Carrera</p>
  382. </div>
  383. <div class="col-6">
  384. <p class="rep-carr"></p>
  385. </div>
  386. </div>
  387. <div class="row">
  388. <div class="col-6 col-sm-4 barra-right text-right">
  389. <p class="font-weight-bold">Materia</p>
  390. </div>
  391. <div class="col-6">
  392. <p class="rep-mat"></p>
  393. </div>
  394. </div>
  395. <div class="row">
  396. <div class="col-6 col-sm-4 barra-right text-right">
  397. <p class="font-weight-bold">Grupo</p>
  398. </div>
  399. <div class="col-6">
  400. <p class="rep-gpo"></p>
  401. </div>
  402. </div>
  403. <div class="row">
  404. <div class="col-6 col-sm-4 barra-right text-right">
  405. <p class="font-weight-bold">Ciclo y bloque</p>
  406. </div>
  407. <div class="col-3">
  408. <p><strong>Ciclo:</strong><span class="rep-ciclo ml-3"></span></p>
  409. </div>
  410. <div class="col-3">
  411. <p><strong>Bloque:</strong><span class="rep-bloque ml-3"></span></p>
  412. </div>
  413. </div>
  414. <div class="row">
  415. <div class="col-6 col-sm-4 barra-right text-right">
  416. <p class="font-weight-bold">Tipo</p>
  417. </div>
  418. <div class="col-6">
  419. <p class="rep-tipo"></p>
  420. </div>
  421. </div>
  422. <div class="row">
  423. <div class="col-6 col-sm-4 barra-right text-right">
  424. <p class="font-weight-bold">Fecha de falta</p>
  425. </div>
  426. <div class="col-6">
  427. <p class="rep-falta"></p>
  428. </div>
  429. </div>
  430. <div class="row">
  431. <div class="col-6 col-sm-4 barra-right text-right">
  432. <p class="font-weight-bold">Fecha de reposición</p>
  433. </div>
  434. <div class="col-6">
  435. <p class="rep-fecha"></p>
  436. </div>
  437. </div>
  438. <div class="row">
  439. <div class="col-6 col-sm-4 barra-right text-right">
  440. <p class="font-weight-bold">Alumnos aproximados</p>
  441. </div>
  442. <div class="col-6">
  443. <p class="rep-alumnos"></p>
  444. </div>
  445. </div>
  446. <div class="row">
  447. <div class="col-6 col-sm-4 barra-right text-right">
  448. <p class="font-weight-bold">Tipo de aula</p>
  449. </div>
  450. <div class="col-6">
  451. <p class="rep-aula"></p>
  452. </div>
  453. </div>
  454. <div class="row" id="salon-ver">
  455. <div class="col-6 col-sm-4 barra-right text-right">
  456. <p class="font-weight-bold">Salón</p>
  457. </div>
  458. <div class="col-6">
  459. <p class="rep-salon"></p>
  460. </div>
  461. </div>
  462. <div class="row" id="salon-editar" style="display: none;">
  463. <div class="col-6 col-sm-4 barra-right text-right">
  464. <p class="font-weight-bold">Salón *</p>
  465. </div>
  466. <div class="col-6">
  467. <input list="lista_salones" name="dlSalon" id="dlSalon" class="form-control" placeholder="Salón">
  468. <div class="valid-feedback">
  469. Salón encontrado
  470. </div>
  471. <div class="invalid-feedback">
  472. Salón no encontrado
  473. </div>
  474. <datalist id="lista_salones">
  475. <?php
  476. foreach ($salones_rs as $salon) {
  477. extract($salon);
  478. $salon_json = json_decode($salon_array, true);
  479. if($salon_json[0]== "UNIVERSIDAD LA SALLE"){
  480. unset($salon_json[0]);
  481. }
  482. $salon_nombre = join(" / ",$salon_json);
  483. ?>
  484. <option data-id="<?= $salon_id ?>" data-nombre="<?= $salon_nombre ?>" value="<?= $salon_nombre ?>"></option>
  485. <?php
  486. }
  487. ?>
  488. </datalist>
  489. <!-- <ul class="list-group" id="salones"></ul> -->
  490. <input type="hidden" id="salon" name="salon" value="">
  491. </div>
  492. </div>
  493. <div class="row" id="supervisor" style="display: none;">
  494. <div class="col-6 col-sm-4 barra-right text-right">
  495. <p class="font-weight-bold">Supervisor</p>
  496. </div>
  497. <div class="col-6">
  498. <p class="rep-sup"></p>
  499. </div>
  500. </div>
  501. <div class="row mt-4">
  502. <div class="col-6 col-sm-4 barra-right text-right">
  503. <p class="font-weight-bold">Comentarios</p>
  504. </div>
  505. <div class="col-6 bg-light">
  506. <p class="rep-comentarios"></p>
  507. </div>
  508. </div>
  509. <div class="row mt-4" id="cancelada-block">
  510. <div class="col-6 col-sm-4 barra-right text-right">
  511. <p class="font-weight-bold text-danger">Motivo de cancelación</p>
  512. </div>
  513. <div class="col-6 bg-light">
  514. <p class="rep-motivo"></p>
  515. </div>
  516. </div>
  517. <div class="form-group row mt-3" id="submitGroup">
  518. <div class="col-12 text-center">
  519. <p class="aprobar-block">Una vez realizada la acción no se puede deshacer.</p>
  520. <p>
  521. <button type="button" class="btn btn-primary btn-enviar aprobar-block" id="submitBtn" ><?php echo $ICO["aceptar"];?> Aprobar</button>
  522. <button type="button" class="btn btn-outline-secondary" data-dismiss="modal" aria-label="Close">Cerrar</button>
  523. </p>
  524. </div>
  525. </div>
  526. <div class="form-group row mt-3" id="loadingGroup" style="display:none">
  527. <div class="col-12 text-center">
  528. <div class="spinner-border text-primary" role="status">
  529. <span class="sr-only">Loading...</span>
  530. </div>
  531. </div>
  532. </div>
  533. </form>
  534. </div>
  535. </div>
  536. </div>
  537. </div>
  538. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  539. <div class="modal-dialog modal-dialog-centered" role="document">
  540. <div class="modal-content">
  541. <div class="modal-body">
  542. <div class="row">
  543. <div class="col">
  544. <p class="font-weight-bold">¿Estás seguro de que quieres declinar la reposición?</p>
  545. <p>Esta acción no se puede deshacer.</p>
  546. </div>
  547. </div>
  548. <form action="./action/reposicion_autoriza.php" method="post">
  549. <div class="row">
  550. <div class="col-6 col-sm-4 barra-right text-right">
  551. <p class="font-weight-bold">Motivo</p>
  552. </div>
  553. <div class="col-6 col-sm-8">
  554. <textarea name="motivo" id="motivo" rows="3" class="form-control"></textarea>
  555. </div>
  556. </div>
  557. <div class="row">
  558. <div class="col-12 mt-4 text-center">
  559. <input type="hidden" id="id_borrar" name="id" value="">
  560. <input type="hidden" name="edo" value="4">
  561. <button type="submit" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Declinar</button>
  562. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cerrar</button>
  563. </div>
  564. </div>
  565. </form>
  566. </div>
  567. </div>
  568. </div>
  569. </div>
  570. <?php
  571. }
  572. ?>
  573. </main>
  574. <? include "import/html_footer.php"; ?>
  575. </body>
  576. <?php
  577. //--Manejo de errores y mensajes de exito
  578. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  579. switch ($_GET["error"]){
  580. case 0: $errorDesc = "No se reciberon los datos de la reposición."; break;
  581. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la reposición/cambio."; break;
  582. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la reposición/cambio."; break;
  583. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  584. case 4: $errorDesc = "Ocurrió un error al cargar los datos de la reposición/cambio."; break;
  585. case 6: $errorDesc = "La reposición/cambio que buscas no existe. Consulta la lista de reopsiciones disponibles en esta sección."; break;
  586. case 7: $errorDesc = "La reposición/cambio se empalma con el horario del grupo y no se puede guardar."; break;
  587. case 8: $errorDesc = "El salón de la reposición está siendo utilizado ese día a esa hora y no se puede guardar."; break;
  588. case 9: $errorDesc = "El profesor está asigndo a otra reposición/cambio el mismo día a la misma hora y no se puede guardar."; break;
  589. case 10: $errorDesc = "El profesor está asigndo a una materia el mismo día a la misma hora y no se puede guardar."; break;
  590. case 11: $errorDesc = "No hay clases asignadas para esa materia y grupo en la fecha de falta."; break;
  591. }
  592. }
  593. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  594. switch ($_GET["ok"]){
  595. case 0: $successDesc = "La reposición se actualizó correctamente."; break;
  596. case 1: $successDesc = "La reposición fue declinada."; break;
  597. }
  598. }
  599. require_once 'js/messages.php';
  600. ?>
  601. <script>
  602. <?php if(isset($errorDesc)){ ?>
  603. triggerMessage("<?php echo $errorDesc;?>", "Error");
  604. <?php } else if(isset($successDesc)){ ?>
  605. triggerMessage("<?php echo $successDesc;?>", "Éxito", "success");
  606. <?php } ?>
  607. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  608. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  609. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final };
  610. function valida(){
  611. <?php
  612. if(!$user->jefe_carrera || $user->admin){ ?>
  613. $("#salon").removeClass("is-invalid");
  614. if($("#salon").val() === undefined || $("#salon").val() == 0 || $("#salon").val() == ''){
  615. $("#salon").addClass("is-invalid");
  616. return false;
  617. }
  618. <?php } ?>
  619. return true;
  620. }
  621. $(document).ready(function(){
  622. $(".date-picker-filtro" ).datepicker(datepickerOptions);
  623. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  624. $('#tab<?php echo $tab_inicial;?>-tab').tab('show');
  625. $('#modal_confirm').on('show.bs.modal', function (event) {
  626. var button = $(event.relatedTarget); // Button that triggered the modal
  627. var id = button.parents("tr").data("id");
  628. $("#id_borrar").val(id);
  629. $("#motivo").val("")
  630. });
  631. $('#dlSalon').on('change', function() {
  632. const selectedValue = $(this).val();
  633. //console.log(selectedValue)
  634. const selectedOption = $(`option[value="${selectedValue}"]`);
  635. //console.log(selectedOption.length)
  636. const salonesList = $('#salones');
  637. if (selectedOption.length) {
  638. const salonId = selectedOption.data('id');
  639. $('#salon').val(salonId);
  640. //const salonNombre = selectedOption.data('nombre');
  641. //salonesList.html(`<li class="list-group-item">${salonNombre}</li>`);
  642. } else {
  643. $('#salon').val('');
  644. //salonesList.empty();
  645. }
  646. });
  647. $('#modal_aprobar').on('show.bs.modal', function (event) {
  648. var button = $(event.relatedTarget); // Button that triggered the modal
  649. var id = button.parents("tr").data("id");
  650. var edo = button.data('estado');
  651. var tipo = button.data('tipo');
  652. $("#loadingGroup").hide();
  653. $("#submitGroup").show();
  654. //1 ver, 2 aprobar, 3 autorizar
  655. $("#edo").val(edo);
  656. $("#id").val(id);
  657. $("#tipo").val(tipo);
  658. var action_pag;
  659. if(tipo == 1 || tipo == 2){
  660. $.ajax({
  661. url: './action/reposicion_select.php',
  662. type: 'POST',
  663. dataType: 'json',
  664. data: { id: id},
  665. success: function(result) {
  666. if(result["error"]!= "" && result["error"] !== undefined){
  667. triggerMessage(result["error"], "Error");
  668. $('#modal_aprobar').modal("hide");
  669. }else{
  670. $("#dlSalon").val("");
  671. $("#modal_aprobar .rep-prof").text(result["profesor_nombre"]);
  672. $("#modal_aprobar .rep-fac").text(result["facultad"]);
  673. $("#modal_aprobar .rep-carr").parents(".row").show();
  674. $("#modal_aprobar .rep-carr").text(result["carrera"]);
  675. $("#modal_aprobar .rep-gpo").parents(".row").show();
  676. $("#modal_aprobar .rep-gpo").text(result["grupo"]);
  677. $("#modal_aprobar .rep-mat").parents(".row").show();
  678. $("#modal_aprobar .rep-mat").text(result["materia_desc"]);
  679. $("#modal_aprobar .rep-ciclo").parents(".row").show();
  680. $("#modal_aprobar .rep-ciclo").text(result["ciclo"]);
  681. $("#modal_aprobar .rep-bloque").text(result["bloque"]);
  682. if(result["tipo"])
  683. $("#modal_aprobar .rep-tipo").text("Reposición");
  684. else
  685. $("#modal_aprobar .rep-tipo").text("Cambio");
  686. $("#modal_aprobar .rep-aula").text(result["aula_desc"])
  687. $("#modal_aprobar .rep-aula").data("aula",result["aula"]);
  688. $("#modal_aprobar .rep-falta").parents(".row").show();
  689. $("#modal_aprobar .rep-falta").text(result["fecha_clase"]);
  690. $("#modal_aprobar .rep-fecha").text(result["fecha_nueva"]+" de "+result["hora_ini"]+":"+result["min_ini"]+" a "+result["hora_fin"]+":"+result["min_fin"]);
  691. if(result["salon"] =="" || result["salon"] === undefined){
  692. $('#salon').prop("selectedIndex", 0);
  693. }else{
  694. $('#salon').val(result["salon"]);
  695. }
  696. $("#modal_aprobar .rep-salon").text(result["salon_desc"]);
  697. $("#modal_aprobar .rep-comentarios").text(result["comentario"]);
  698. $('#modal_aprobar .rep-alumnos').text(result["alumnos"]);
  699. if(result["supervisor_nombre"]!=""){
  700. $("#supervisor").show();
  701. $("#modal_aprobar .rep-sup").text(result["supervisor_nombre"]);
  702. }else{
  703. $("#supervisor").hide();
  704. }
  705. if(result["estado"] == 4){//cancelada
  706. $('#modal_aprobar .rep-motivo').text(result["motivo_cancelacion"]);
  707. $("#cancelada-block").show();
  708. }else{
  709. $("#cancelada-block").hide();
  710. }
  711. if(edo == 1){// 1 ver
  712. $("#modalLabel").text("Detalle de reposición");
  713. $(".aprobar-block").hide();
  714. /*if(parseInt($("#modal_aprobar .rep-aula").data("aula")) != 1){//tipo aula 1 (salon normal) - ver
  715. $("#salon-ver").hide();
  716. $("#salon-editar").show();
  717. }else{
  718. $("#salon-ver").show();
  719. $("#salon-editar").hide();
  720. }*/
  721. $("#salon-ver").show();
  722. $("#salon-editar").hide();
  723. }else{
  724. $("#modalLabel").text("Aprobar reposición");
  725. $(".aprobar-block").show();
  726. if(edo == 2 && parseInt($("#modal_aprobar .rep-aula").data("aula")) == 1){//tipo aula 1 (salon normal) - ver
  727. $("#salon-ver").show();
  728. $("#salon-editar").hide();
  729. }else if(edo == 3 && parseInt($("#modal_aprobar .rep-aula").data("aula")) != 1){//aprobar (con salón especial)
  730. $("#salon-ver").show();
  731. $("#salon-editar").hide();
  732. }else{
  733. $("#salon-ver").hide();
  734. $("#salon-editar").show();
  735. }
  736. }
  737. if(result["aula_supervisor"]){//Solo supervisor
  738. <?php if($supervisor){ ?>
  739. $("#salon-editar").attr("disabled", false);
  740. <?php }else{?>
  741. $("#salon-editar").attr("disabled", true);
  742. <?php } ?>
  743. }else{// Facultad
  744. <?php if(!$supervisor){ ?>
  745. $("#salon-editar").attr("disabled", false);
  746. <?php }else{?>
  747. $("#salon-editar").attr("disabled", true);
  748. <?php } ?>
  749. }
  750. }
  751. },
  752. error: function(jqXHR, textStatus, errorThrown ){
  753. triggerMessage(errorThrown, "Error");
  754. }
  755. });//ajax
  756. }else{
  757. $.ajax({
  758. url: './action/asignacion_select.php',
  759. type: 'POST',
  760. dataType: 'json',
  761. data: { id: id},
  762. success: function(result) {
  763. if(result["error"]!= "" && result["error"] !== undefined){
  764. triggerMessage(result["error"], "Error");
  765. $('#modal_aprobar').modal("hide");
  766. }else{
  767. $("#dlSalon").val("");
  768. $("#modal_aprobar .rep-prof").text(result["profesor_nombre"]);
  769. $("#modal_aprobar .rep-fac").text(result["facultad"]);
  770. $("#modal_aprobar .rep-carr").parents(".row").hide();
  771. $("#modal_aprobar .rep-gpo").parents(".row").hide();
  772. $("#modal_aprobar .rep-mat").parents(".row").hide();
  773. $("#modal_aprobar .rep-ciclo").parents(".row").hide();
  774. $("#modal_aprobar .rep-tipo").text("Asignación");
  775. $("#modal_aprobar .rep-aula").text(result["aula_desc"])
  776. $("#modal_aprobar .rep-aula").data("aula",result["aula"]);
  777. $("#modal_aprobar .rep-falta").parents(".row").hide();
  778. $("#modal_aprobar .rep-fecha").text(result["fecha_nueva"]+" de "+result["hora_ini"]+":"+result["min_ini"]+" a "+result["hora_fin"]+":"+result["min_fin"]);
  779. if(result["salon"] =="" || result["salon"] === undefined){
  780. $('#salon').prop("selectedIndex", 0);
  781. }else{
  782. $('#salon').val(result["salon"]);
  783. }
  784. $("#modal_aprobar .rep-salon").text(result["salon_desc"]);
  785. $("#modal_aprobar .rep-comentarios").text(result["comentario"]);
  786. $('#modal_aprobar .rep-alumnos').text(result["alumnos"]);
  787. if(result["supervisor_nombre"]!=""){
  788. $("#supervisor").show();
  789. $("#modal_aprobar .rep-sup").text(result["supervisor_nombre"]);
  790. }else{
  791. $("#supervisor").hide();
  792. }
  793. if(result["estado"] == 4){//cancelada
  794. $('#modal_aprobar .rep-motivo').text(result["motivo_cancelacion"]);
  795. $("#cancelada-block").show();
  796. }else{
  797. $("#cancelada-block").hide();
  798. }
  799. if(edo == 1){// 1 ver
  800. $("#modalLabel").text("Detalle de reposición");
  801. $(".aprobar-block").hide();
  802. /*if(parseInt($("#modal_aprobar .rep-aula").data("aula")) != 1){//tipo aula 1 (salon normal) - ver
  803. $("#salon-ver").hide();
  804. $("#salon-editar").show();
  805. }else{
  806. $("#salon-ver").show();
  807. $("#salon-editar").hide();
  808. }*/
  809. $("#salon-ver").show();
  810. $("#salon-editar").hide();
  811. }else{
  812. $("#modalLabel").text("Aprobar reposición");
  813. $(".aprobar-block").show();
  814. if(edo == 2 && parseInt($("#modal_aprobar .rep-aula").data("aula")) == 1){//tipo aula 1 (salon normal) - ver
  815. $("#salon-ver").show();
  816. $("#salon-editar").hide();
  817. }else if(edo == 3 && parseInt($("#modal_aprobar .rep-aula").data("aula")) != 1){//aprobar (con salón especial)
  818. $("#salon-ver").show();
  819. $("#salon-editar").hide();
  820. }else{
  821. $("#salon-ver").hide();
  822. $("#salon-editar").show();
  823. }
  824. }
  825. if(result["aula_supervisor"]){//Solo supervisor
  826. <?php if($supervisor){ ?>
  827. $("#salon-editar").attr("disabled", false);
  828. <?php }else{?>
  829. $("#salon-editar").attr("disabled", true);
  830. <?php } ?>
  831. }else{// Facultad
  832. <?php if(!$supervisor){ ?>
  833. $("#salon-editar").attr("disabled", false);
  834. <?php }else{?>
  835. $("#salon-editar").attr("disabled", true);
  836. <?php } ?>
  837. }
  838. }
  839. },
  840. error: function(jqXHR, textStatus, errorThrown ){
  841. triggerMessage(errorThrown, "Error");
  842. }
  843. });//ajax
  844. }
  845. });
  846. /*
  847. $(".btn-borrar").click(function(){
  848. var cid = $("#id_borrar").val();
  849. $.ajax({
  850. url: './action/reposicion_autoriza.php',
  851. type: 'POST',
  852. dataType: 'json',
  853. data: { id: cid, edo: 4},
  854. success: function(result) {
  855. if(result["error"]!= "" && result["error"] !== undefined){
  856. $("#errorBox").collapse('show');
  857. $("#errorBox_text").html(result["error"]);
  858. }else{
  859. $("#successBox").collapse('show');
  860. $("#successBox_text").html(result["ok"]);
  861. $("#id"+cid).remove();
  862. }
  863. $('#messageBox')[0].scrollIntoView({ block: "end" });
  864. },
  865. error: function(jqXHR, textStatus, errorThrown ){
  866. $("#errorBox").collapse('show');
  867. $("#errorBox_text").html(errorThrown);
  868. $('#messageBox')[0].scrollIntoView({ block: "end" });
  869. }
  870. });//ajax
  871. $('#modal_confirm').modal("hide");
  872. });*/
  873. $("#submitBtn").click(function(){
  874. var edo = parseInt($("#edo").val());
  875. console.log(edo)
  876. if((edo == 3 && valida()) || edo == 2){
  877. $("#loadingGroup").show();
  878. $("#submitGroup").hide();
  879. $("#formaModal").submit();
  880. }
  881. });
  882. });
  883. function validaFiltro(){
  884. if($('#filter_fecha_ini').val() != "" && !validaFecha($('#filter_fecha_ini').val()) ){
  885. $('#filter_fecha_ini').addClass("is-invalid");
  886. return false;
  887. }
  888. if($('#filter_fecha_fin').val() != "" && !validaFecha($('#filter_fecha_fin').val())){
  889. $('#filter_fecha_fin').addClass("is-invalid");
  890. return false;
  891. }
  892. if($('#filter_fecha_ini').val() != "" && $('#filter_fecha_fin').val() != "" && fechaMayor($('#filter_fecha_ini').val(), $('#filter_fecha_fin').val()) >= 0){
  893. $('#filter_fecha_fin').addClass("is-invalid");
  894. return false;
  895. }
  896. return true;
  897. }
  898. $(function() {
  899. $('[data-toggle="tooltip"]').tooltip()
  900. });
  901. /**@Auxiliary functions */
  902. function listProfesor({
  903. id,
  904. grado,
  905. profesor,
  906. clave
  907. }) {
  908. const lista = document.getElementById("dlProfesor");
  909. lista.innerHTML = "";
  910. lista.classList.remove("is-invalid");
  911. const li = document.createElement('li');
  912. li.setAttribute('data-id', id);
  913. li.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
  914. li.innerHTML = `${clave} | ${grado ?? ''} ${profesor}`
  915. const btn = document.createElement('button');
  916. btn.setAttribute('type', 'button');
  917. btn.classList.add('badge', 'badge-danger', 'badge-pill', 'border-0');
  918. btn.onclick = _ => li.remove();
  919. const i = document.createElement('i');
  920. i.classList.add('ing-cancelar');
  921. btn.appendChild(i);
  922. li.appendChild(btn);
  923. document.getElementById("profesores").appendChild(li);
  924. }
  925. function listSalon({
  926. id,
  927. nombre
  928. }) {
  929. const lista = document.getElementById("dlSalon");
  930. lista.innerHTML = "";
  931. lista.classList.remove("is-invalid");
  932. const li = document.createElement('li');
  933. li.setAttribute('data-id', id);
  934. li.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
  935. li.innerHTML = `${nombre}`
  936. const btn = document.createElement('button');
  937. btn.setAttribute('type', 'button');
  938. btn.classList.add('badge', 'badge-danger', 'badge-pill', 'border-0');
  939. btn.onclick = _ => li.remove();
  940. const i = document.createElement('i');
  941. i.classList.add('ing-cancelar');
  942. btn.appendChild(i);
  943. li.appendChild(btn);
  944. document.getElementById("salones").appendChild(li);
  945. }
  946. </script>
  947. </html>