solicitudes_autorizar.php 52 KB

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