solicitudes_autorizar.php 52 KB

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