reposiciones_autorizar.php 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861
  1. <?php
  2. require_once 'class/c_login.php';
  3. if (!isset($_SESSION['user'])){
  4. die(header('Location: index.php'));
  5. }
  6. //$user = unserialize($_SESSION['user']);
  7. $user = Login::get_user();
  8. $user->access();
  9. //echo $user;
  10. /*print_r($user);
  11. print_r($user->user["id"]);
  12. echo "****|";
  13. print_r($user->acceso);//null sin permisos, w o r
  14. echo "|****|";
  15. print_r($user->profesor);
  16. echo "|****|";
  17. print_r($user->facultad["facultad_id"]);
  18. exit();*/
  19. //profesor, admin, rol, facultad
  20. if ($user->acceso === null && !$user->admin){
  21. die(header('Location: index.php'));
  22. exit();
  23. }
  24. $supervisor = false;
  25. $coordinador = false;
  26. if($user->rol["rol_id"]==7){
  27. $supervisor = true;
  28. }
  29. if($user->rol["rol_id"]==9){
  30. $coordinador = true;
  31. }
  32. //$user->print_to_log('Reposiciones');
  33. //$write = $user->admin || in_array($user->acceso, ['w']);
  34. $write = true; //
  35. function duracionMinutos($fechahora_i, $fechahora_f){
  36. return round((strtotime($fechahora_f) - strtotime($fechahora_i)) / 60,2);
  37. }
  38. if($user->periodo_id!= ""){
  39. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo_id])['esta_en_periodo'];
  40. $profesores_rs = array();
  41. $tab_inicial = 1;
  42. if(!$supervisor){
  43. $fac_id = $user->facultad["facultad_id"];
  44. $carrera_rs = $db->query('SELECT * FROM fs_profesor_facultad(:fac, :periodo)', [':fac'=>$fac_id, ':periodo' => $user->periodo_id]);
  45. }else{
  46. $carrera_rs = $db->query('SELECT * FROM fs_profesor_facultad(NULL, :periodo)', [ ':periodo' => $user->periodo_id]);
  47. }
  48. $salones_rs = $db->query('SELECT * from salon_view where es_salon is true');
  49. //Periodo
  50. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo_id]);
  51. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  52. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  53. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  54. else{
  55. $dias = 3;
  56. if( intval(date("w")) >=3 && intval(date("w"))<=5 )//Mie a Vie
  57. $dias+=3;
  58. else if( intval(date("w")) ==6 )//Sab
  59. $dias+=2;
  60. else if( intval(date("w")) ==0 )//Do
  61. $dias+=1;
  62. $fecha_man = date("d/m/Y", strtotime("+".$dias." day"));
  63. }
  64. // Fechas filtro
  65. if(isset($_POST["fecha_inicial"]))
  66. $fecha_ini = $_POST["fecha_inicial"];
  67. else
  68. $fecha_ini = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  69. if(isset($_POST["fecha_final"]))
  70. $fecha_fin = $_POST["fecha_final"];
  71. else
  72. $fecha_fin = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"]));
  73. //Reposiciones
  74. $repEdo_rs = $db->query('SELECT * FROM fs_estado_reposicion' );
  75. $repoParams = array();
  76. $query = "NULL,";//jefe carrera
  77. /*if($user->jefe_carrera){
  78. $query .= ":jefe, ";
  79. $repoParams[":jefe"] = $user->user["id"];
  80. }else{
  81. $query .= "NULL, ";
  82. }*/
  83. if($user->rol["rol_id"] == 9){//es coordinador
  84. $query .= ":facultad, ";
  85. $repoParams[":facultad"] = $user->facultad["facultad_id"];
  86. }else{//supervisor
  87. $query .= "NULL, ";
  88. }
  89. if((isset($_POST["prof"]) && is_numeric($_POST["prof"])) ){
  90. $query .= ":prof,";
  91. $repoParams[":prof"] = filter_input(INPUT_POST, "prof", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  92. }else{
  93. $query .= "NULL,";
  94. }
  95. $query .= ":f_ini, :f_fin, :edo, ";
  96. $date = DateTime::createFromFormat('d/m/Y', $fecha_ini);
  97. $fecha_ini_db = $date->format('Y-m-d');
  98. $date = DateTime::createFromFormat('d/m/Y', $fecha_fin);
  99. $fecha_fin_db = $date->format('Y-m-d');
  100. $repoParams[":f_ini"] = $fecha_ini_db;
  101. $repoParams[":f_fin"] = $fecha_fin_db;
  102. $repoParams[":edo"] = 1;//se sobreescribe
  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 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 for="filtro_prof" class="col-4 col-form-label">Profesor</label>
  163. <div class="col-8 col-sm-4">
  164. <input list="lista_profesores" name="dlProfesor" id="dlProfesor" class="form-control" placeholder="Profesor">
  165. <div class="valid-feedback">
  166. Profesor encontrado
  167. </div>
  168. <div class="invalid-feedback">
  169. Profesor no encontrado
  170. </div>
  171. <datalist id="lista_profesores">
  172. <?php
  173. foreach ($profesores_rs as $profesor) {
  174. extract($profesor);
  175. ?>
  176. <option data-clave="<?= $profesor_clave ?>" data-profesor="<?= $profesor_nombre ?>" data-id="<?= $profesor_id; ?>" value="<?= "$profesor_clave | $profesor_nombre" ?>"></option>
  177. <?php
  178. }
  179. ?>
  180. </datalist>
  181. <ul class="list-group" id="profesores"></ul>
  182. <input type="hidden" id="editor_profesor" name="profesor" value="">
  183. </div>
  184. </div>
  185. </div>
  186. <div class="form-group row justify-content-center">
  187. <button type="submit" class="btn btn-outline-primary mr-2" id="btn-buscar"><span class="ing-buscar ing-fw"></span> Buscar</button>
  188. <button type="button" class="btn btn-outline-danger" onclick="window.location.href = window.location.href"><span class="ing-borrar ing-fw"></span> Limpiar</button>
  189. </div>
  190. </form>
  191. <ul class="nav nav-tabs d-print-none mb-4" id="myTab" role="tablist">
  192. <li class="nav-item">
  193. <a class="nav-link" id="tab1-tab" data-toggle="tab" href="#tab1" role="tab" aria-controls="calendario" aria-selected="true">Nuevas reposiciones</a>
  194. </li>
  195. <li class="nav-item">
  196. <a class="nav-link" id="tab2-tab" data-toggle="tab" href="#tab2" role="tab" aria-controls="lista" aria-selected="false">Aprobadas por Facultad</a>
  197. </li>
  198. <li class="nav-item">
  199. <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>
  200. </li>
  201. <li class="nav-item">
  202. <a class="nav-link" id="tab4-tab" data-toggle="tab" href="#tab4" role="tab" aria-controls="lista" aria-selected="false">Declinadas</a>
  203. </li>
  204. </ul>
  205. <div class="tab-content" id="TabContent">
  206. <?php
  207. $i=1;
  208. foreach($repEdo_rs as $redo){ ?>
  209. <div class="tab-pane fade" id="tab<?php echo $i;?>" role="tabpanel" aria-labelledby="tab<?php echo $i;?>-tab">
  210. <?php
  211. $repoParams[":edo"]=$redo["estado_reposicion_id"];
  212. $reposiciones_rs = $db->query('SELECT * FROM fs_reposicion(NULL, '.$query.'0, NULL) ', $repoParams );
  213. ?>
  214. <h4 class="mb-4" <?php echo "style='color:".$redo["estado_color"]."'>".$redo["estado_nombre"]; ?> </h4>
  215. <table class="table table-sm table-striped table-white">
  216. <thead class="thead-dark">
  217. <tr>
  218. <th>Estado</th>
  219. <th>Tipo</th>
  220. <th>Profesor/Materia</th>
  221. <th style="width:160px">Fecha falta</th>
  222. <th style="width:160px">Fecha reposición</th>
  223. <th>Salón</th>
  224. <?php if($write){ ?><th>Acciones</th><?php } ?>
  225. </tr>
  226. </thead>
  227. <tbody>
  228. <?php
  229. if(isset($reposiciones_rs)){
  230. foreach($reposiciones_rs as $reposicion){
  231. ?>
  232. <tr data-id="<?php echo $reposicion["reposicion_solicitud_id"]; ?>" data-edo="<?php echo $reposicion["estado_reposicion_id"];?>" id="id<?php echo $reposicion["reposicion_solicitud_id"]; ?>">
  233. <td class="align-middle">
  234. <?php if($reposicion["estado_reposicion_id"]<3){ ?>
  235. <div class="wizard <?php if(intval($reposicion["estado_reposicion_id"])==2) echo "active";?> d-flex mx-auto">
  236. <div class="w-50 h-100"></div>
  237. <div class=""></div>
  238. </div>
  239. <?php } else if($reposicion["estado_reposicion_id"]==3){?>
  240. <div class="text-success text-center pt-1">
  241. <span class="ing-autorizar ing-lg"></span>
  242. </div>
  243. <?php } else {?>
  244. <div class="text-danger text-center pt-1">
  245. <span class="ing-negar ing-lg"></span>
  246. </div>
  247. <?php } ?>
  248. </td>
  249. <td class="align-middle">
  250. <?php if($reposicion["es_reposicion"]) echo "Resposición"; else echo "Cambio"; ?>
  251. </td>
  252. <td><?php
  253. echo $reposicion["profesor_clave"]." - ".$reposicion["profesor_nombre"];
  254. ?>
  255. <br>
  256. <small>
  257. <?php echo $reposicion["materia_nombre"]; ?>
  258. (<?php
  259. echo $reposicion["horario_grupo"];
  260. ?>)
  261. </small>
  262. </td>
  263. <td class="text-center align-middle text-nowrap"><?php
  264. $fechaI = date("d/m/Y", strtotime($reposicion["fecha_clase"]));
  265. echo $fechaI."<br>".substr($reposicion["horario_hora"],0, 5);
  266. ?>
  267. </td>
  268. <td class="text-center align-middle text-nowrap"><?php
  269. $fechaF = date("d/m/Y", strtotime($reposicion["fecha_nueva"]));
  270. echo $fechaF."<br>".substr($reposicion["hora_nueva"],0, 5)." a ".substr($reposicion["hora_nueva_fin"],0, 5);
  271. ?>
  272. </td>
  273. <td class="text-center align-middle"><?php
  274. if($reposicion["salon_id"] != ""){
  275. $salon_json = json_decode($reposicion["salon_array"], true);
  276. echo $salon_json[count($salon_json)-1];
  277. }else
  278. echo "Pendiente";
  279. ?>
  280. </td>
  281. <?php if($write){ ?>
  282. <td class="text-center align-middle icono-acciones text-nowrap">
  283. <?php if (duracionMinutos($reposicion["fecha_nueva"], date("Y-m-d H:i:00")) < 0){ ?>
  284. <?php //no se cumple la fecha de la reposicion, es jefe de carrera
  285. if((!$user->jefe_carrera || $user->admin || !$coordinador) && $reposicion["estado_reposicion_id"] == 1){?>
  286. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="2" title="Aprobar"><?php echo $ICO["ver"];?></a>
  287. <?php } //no se cumple la fecha de la reposicion, no es jefe de carrera
  288. else if(($supervisor || $user->admin) && $reposicion["estado_reposicion_id"] == 2){?>
  289. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="3" title="Autorizar" ><?php echo $ICO["ver"];?></a>
  290. <?php } else { ?>
  291. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="1" title="Ver detalle"><?php echo $ICO["ver"];?></a>
  292. <?php } ?>
  293. <?php
  294. }else{ //fecha ya pasó?>
  295. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="1" title="Ver detalle"><span class="text-danger"><?php echo $ICO["ver"];?></span></a>
  296. <?php } ?>
  297. <?php
  298. if($reposicion["estado_reposicion_id"]<4){
  299. if(
  300. (($user->jefe_carrera || $user->admin || $coordinador) && $reposicion["estado_reposicion_id"] == 1)/* nueva */
  301. || (($user->admin || $coordinador || $supervisor) && $reposicion["estado_reposicion_id"] == 2)/* aprobado facultad */
  302. ){
  303. ?>
  304. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Cancelar"><span class="text-danger"><?php echo $ICO["cancelar"];?></span></a>
  305. <?php }
  306. } //estado
  307. ?>
  308. </td>
  309. <?php }//edición ?>
  310. </tr>
  311. <?php
  312. }//foreach
  313. }//if ?>
  314. </tbody>
  315. </table>
  316. </div>
  317. <?php
  318. $i++;
  319. } ?>
  320. </div>
  321. <!-- Modal -->
  322. <div class="modal fade" id="modal_aprobar" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  323. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  324. <div class="modal-content">
  325. <div class="modal-header">
  326. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Aprobar Reposición</span>
  327. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  328. <span aria-hidden="true">&times;</span>
  329. </button></h4>
  330. </div>
  331. <div class="modal-body">
  332. <form action="./action/reposicion_autoriza.php" method="post" id="formaModal">
  333. <input type="hidden" name="id" id="id">
  334. <input type="hidden" name="edo" id="edo" 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 class="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 class="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">Materia</p>
  354. </div>
  355. <div class="col-6">
  356. <p class="rep-mat"></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">Ciclo y bloque</p>
  362. </div>
  363. <div class="col-3">
  364. <p><strong>Ciclo:</strong><span class="rep-ciclo ml-3"></span></p>
  365. </div>
  366. <div class="col-3">
  367. <p><strong>Bloque:</strong><span class="rep-bloque ml-3"></span></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">Tipo</p>
  373. </div>
  374. <div class="col-6">
  375. <p class="rep-tipo"></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">Fecha de falta</p>
  381. </div>
  382. <div class="col-6">
  383. <p class="rep-falta"></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">Fecha de reposición</p>
  389. </div>
  390. <div class="col-6">
  391. <p class="rep-fecha"></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">Alumnos aproximados</p>
  397. </div>
  398. <div class="col-6">
  399. <p class="rep-alumnos"></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">Tipo de aula</p>
  405. </div>
  406. <div class="col-6">
  407. <p class="rep-aula"></p>
  408. </div>
  409. </div>
  410. <div class="row" id="salon-ver">
  411. <div class="col-6 col-sm-4 barra-right text-right">
  412. <p class="font-weight-bold">Salón</p>
  413. </div>
  414. <div class="col-6">
  415. <p class="rep-salon"></p>
  416. </div>
  417. </div>
  418. <div class="row" id="salon-editar" style="display: none;">
  419. <div class="col-6 col-sm-4 barra-right text-right">
  420. <p class="font-weight-bold">Salón *</p>
  421. </div>
  422. <div class="col-6">
  423. <input list="lista_salones" name="dlSalon" id="dlSalon" class="form-control" placeholder="Salón">
  424. <div class="valid-feedback">
  425. Salón encontrado
  426. </div>
  427. <div class="invalid-feedback">
  428. Salón no encontrado
  429. </div>
  430. <datalist id="lista_salones">
  431. <?php
  432. foreach ($salones_rs as $salon) {
  433. extract($salon);
  434. $salon_json = json_decode($salon_array, true);
  435. if($salon_json[0]== "UNIVERSIDAD LA SALLE"){
  436. unset($salon_json[0]);
  437. }
  438. $salon_nombre = join(" / ",$salon_json);
  439. ?>
  440. <option data-id="<?= $salon_id ?>" data-nombre="<?= $salon_nombre ?>" value="<?= $salon_nombre ?>"></option>
  441. <?php
  442. }
  443. ?>
  444. </datalist>
  445. <!-- <ul class="list-group" id="salones"></ul> -->
  446. <input type="hidden" id="salon" name="salon" value="">
  447. </div>
  448. </div>
  449. <div class="row mt-4">
  450. <div class="col-6 col-sm-4 barra-right text-right">
  451. <p class="font-weight-bold">Comentarios</p>
  452. </div>
  453. <div class="col-6 bg-light">
  454. <p class="rep-comentarios"></p>
  455. </div>
  456. </div>
  457. <div class="row mt-4" id="cancelada-block">
  458. <div class="col-6 col-sm-4 barra-right text-right">
  459. <p class="font-weight-bold text-danger">Motivo de cancelación</p>
  460. </div>
  461. <div class="col-6 bg-light">
  462. <p class="rep-motivo"></p>
  463. </div>
  464. </div>
  465. <div class="form-group row mt-3">
  466. <div class="col-12 text-center">
  467. <p class="aprobar-block">Una vez realizada la acción no se puede deshacer.</p>
  468. <p>
  469. <button type="button" class="btn btn-primary btn-enviar aprobar-block" id="submitBtn" data-edo="<?php echo $edo_new; ?>" ><?php echo $ICO["aceptar"];?> Aprobar</button>
  470. <button type="button" class="btn btn-outline-secondary" data-dismiss="modal" aria-label="Close">Cerrar</button>
  471. </p>
  472. </div>
  473. </div>
  474. </form>
  475. </div>
  476. </div>
  477. </div>
  478. </div>
  479. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  480. <div class="modal-dialog modal-dialog-centered" role="document">
  481. <div class="modal-content">
  482. <div class="modal-body">
  483. <div class="row">
  484. <div class="col">
  485. <p class="font-weight-bold">¿Estás seguro de que quieres declinar la reposición?</p>
  486. <p>Esta acción no se puede deshacer.</p>
  487. </div>
  488. </div>
  489. <form action="./action/reposicion_autoriza.php" method="post">
  490. <div class="row">
  491. <div class="col-6 col-sm-4 barra-right text-right">
  492. <p class="font-weight-bold">Motivo</p>
  493. </div>
  494. <div class="col-6 col-sm-8">
  495. <textarea name="motivo" id="motivo" rows="3" class="form-control"></textarea>
  496. </div>
  497. </div>
  498. <div class="row">
  499. <div class="col-12 mt-4 text-center">
  500. <input type="hidden" id="id_borrar" name="id" value="">
  501. <input type="hidden" name="edo" value="4">
  502. <button type="submit" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Declinar</button>
  503. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cerrar</button>
  504. </div>
  505. </div>
  506. </form>
  507. </div>
  508. </div>
  509. </div>
  510. </div>
  511. <?php
  512. }
  513. ?>
  514. </main>
  515. <? include "import/html_footer.php"; ?>
  516. </body>
  517. <?php
  518. //--Manejo de errores y mensajes de exito
  519. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  520. switch ($_GET["error"]){
  521. case 0: $errorDesc = "No se reciberon los datos de la reposición."; break;
  522. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la reposición/cambio."; break;
  523. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la reposición/cambio."; break;
  524. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  525. case 4: $errorDesc = "Ocurrió un error al cargar los datos de la reposición/cambio."; break;
  526. case 6: $errorDesc = "La reposición/cambio que buscas no existe. Consulta la lista de reopsiciones disponibles en esta sección."; break;
  527. case 7: $errorDesc = "La reposición/cambio se empalma con el horario del grupo y no se puede guardar."; break;
  528. 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;
  529. 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;
  530. case 10: $errorDesc = "El profesor está asigndo a una materia el mismo día a la misma hora y no se puede guardar."; break;
  531. case 11: $errorDesc = "No hay clases asignadas para esa materia y grupo en la fecha de falta."; break;
  532. }
  533. }
  534. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  535. switch ($_GET["ok"]){
  536. case 0: $successDesc = "La reposición se guardó correctamente."; break;
  537. case 1: $successDesc = "La reposición se actualizó correctamente."; break;
  538. }
  539. }
  540. require_once 'js/messages.php';
  541. ?>
  542. <script>
  543. <?php if(isset($errorDesc)){ ?>
  544. triggerMessage("<?php echo $errorDesc;?>", "Error");
  545. <?php } else if(isset($successDesc)){ ?>
  546. triggerMessage("<?php echo $successDesc;?>", "Éxito", "success");
  547. <?php } ?>
  548. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  549. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  550. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final };
  551. function valida(){
  552. <?php
  553. if(!$user->jefe_carrera || $user->admin){ ?>
  554. $("#salon").removeClass("is-invalid");
  555. if($("#salon").val() === undefined || $("#salon").val() == 0 || $("#salon").val() == ''){
  556. $("#salon").addClass("is-invalid");
  557. return false;
  558. }
  559. <?php } ?>
  560. return true;
  561. }
  562. $(document).ready(function(){
  563. $(".date-picker-filtro" ).datepicker(datepickerOptions);
  564. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  565. $('#tab<?php echo $tab_inicial;?>-tab').tab('show');
  566. $('#modal_confirm').on('show.bs.modal', function (event) {
  567. var button = $(event.relatedTarget); // Button that triggered the modal
  568. var id = button.parents("tr").data("id");
  569. $("#id_borrar").val(id);
  570. $("#motivo").val("")
  571. });
  572. $('#dlSalon').on('change', function() {
  573. const selectedValue = $(this).val();
  574. //console.log(selectedValue)
  575. const selectedOption = $(`option[value="${selectedValue}"]`);
  576. //console.log(selectedOption.length)
  577. const salonesList = $('#salones');
  578. if (selectedOption.length) {
  579. const salonId = selectedOption.data('id');
  580. $('#salon').val(salonId);
  581. //const salonNombre = selectedOption.data('nombre');
  582. //salonesList.html(`<li class="list-group-item">${salonNombre}</li>`);
  583. } else {
  584. $('#salon').val('');
  585. //salonesList.empty();
  586. }
  587. });
  588. $('#modal_aprobar').on('show.bs.modal', function (event) {
  589. var button = $(event.relatedTarget); // Button that triggered the modal
  590. var id = button.parents("tr").data("id");
  591. var edo = button.data('tipo');
  592. //1 ver, 2 aprobar, 3 autorizar
  593. $("#edo").val(edo);
  594. $("#id").val(id);
  595. $.ajax({
  596. url: './action/reposicion_select.php',
  597. type: 'POST',
  598. dataType: 'json',
  599. data: { id: id},
  600. success: function(result) {
  601. if(result["error"]!= "" && result["error"] !== undefined){
  602. triggerMessage(result["error"], "Error");
  603. $('#modal_aprobar').modal("hide");
  604. }else{
  605. $("#dlSalon").val("");
  606. $("#modal_aprobar .rep-prof").text(result["profesor_nombre"]);
  607. $("#modal_aprobar .rep-fac").text(result["facultad"]);
  608. $("#modal_aprobar .rep-mat").text(result["materia_desc"]);
  609. $("#modal_aprobar .rep-ciclo").text(result["ciclo"]);
  610. $("#modal_aprobar .rep-bloque").text(result["bloque"]);
  611. if(result["tipo"])
  612. $("#modal_aprobar .rep-tipo").text("Reposición");
  613. else
  614. $("#modal_aprobar .rep-tipo").text("Cambio");
  615. $("#modal_aprobar .rep-aula").text(result["aula_desc"])
  616. $("#modal_aprobar .rep-aula").data("aula",result["aula"]);
  617. $("#modal_aprobar .rep-falta").text(result["fecha_clase"]);
  618. $("#modal_aprobar .rep-fecha").text(result["fecha_nueva"]+" de "+result["hora_ini"]+":"+result["min_ini"]+" a "+result["hora_fin"]+":"+result["min_fin"]);
  619. if(result["salon"] =="" || result["salon"] === undefined){
  620. $('#salon').prop("selectedIndex", 0);
  621. }else{
  622. $('#salon').val(result["salon"]);
  623. }
  624. $("#modal_aprobar .rep-salon").text(result["salon_desc"]);
  625. $("#modal_aprobar .rep-comentarios").text(result["comentario"]);
  626. $('#modal_aprobar .rep-alumnos').text(result["alumnos"]);
  627. if(result["estado"] == 4){//cancelada
  628. $('#modal_aprobar .rep-motivo').text(result["motivo_cancelacion"]);
  629. $("#cancelada-block").show();
  630. }else{
  631. $("#cancelada-block").hide();
  632. }
  633. if(edo == 1){// 1 ver
  634. $("#modalLabel").text("Detalle de reposición");
  635. $(".aprobar-block").hide();
  636. /*if(parseInt($("#modal_aprobar .rep-aula").data("aula")) != 1){//tipo aula 1 (salon normal) - ver
  637. $("#salon-ver").hide();
  638. $("#salon-editar").show();
  639. }else{
  640. $("#salon-ver").show();
  641. $("#salon-editar").hide();
  642. }*/
  643. $("#salon-ver").show();
  644. $("#salon-editar").hide();
  645. }else{
  646. $("#modalLabel").text("Aprobar reposición");
  647. $(".aprobar-block").show();
  648. if(edo == 2 && parseInt($("#modal_aprobar .rep-aula").data("aula")) == 1){//tipo aula 1 (salon normal) - ver
  649. $("#salon-ver").show();
  650. $("#salon-editar").hide();
  651. }else if(edo == 3 && parseInt($("#modal_aprobar .rep-aula").data("aula")) != 1){//aprobar (con salón especial)
  652. $("#salon-ver").show();
  653. $("#salon-editar").hide();
  654. }else{
  655. $("#salon-ver").hide();
  656. $("#salon-editar").show();
  657. }
  658. }
  659. if(result["aula_supervisor"]){//Solo supervisor
  660. <?php if($supervisor){ ?>
  661. $("#salon-editar").attr("disabled", false);
  662. <?php }else{?>
  663. $("#salon-editar").attr("disabled", true);
  664. <?php } ?>
  665. }else{// Facultad
  666. <?php if(!$supervisor){ ?>
  667. $("#salon-editar").attr("disabled", false);
  668. <?php }else{?>
  669. $("#salon-editar").attr("disabled", true);
  670. <?php } ?>
  671. }
  672. }
  673. },
  674. error: function(jqXHR, textStatus, errorThrown ){
  675. triggerMessage(errorThrown, "Error");
  676. }
  677. });//ajax
  678. });
  679. /*
  680. $(".btn-borrar").click(function(){
  681. var cid = $("#id_borrar").val();
  682. $.ajax({
  683. url: './action/reposicion_autoriza.php',
  684. type: 'POST',
  685. dataType: 'json',
  686. data: { id: cid, edo: 4},
  687. success: function(result) {
  688. if(result["error"]!= "" && result["error"] !== undefined){
  689. $("#errorBox").collapse('show');
  690. $("#errorBox_text").html(result["error"]);
  691. }else{
  692. $("#successBox").collapse('show');
  693. $("#successBox_text").html(result["ok"]);
  694. $("#id"+cid).remove();
  695. }
  696. $('#messageBox')[0].scrollIntoView({ block: "end" });
  697. },
  698. error: function(jqXHR, textStatus, errorThrown ){
  699. $("#errorBox").collapse('show');
  700. $("#errorBox_text").html(errorThrown);
  701. $('#messageBox')[0].scrollIntoView({ block: "end" });
  702. }
  703. });//ajax
  704. $('#modal_confirm').modal("hide");
  705. });*/
  706. $("#submitBtn").click(function(){
  707. var edo = parseInt($("#edo").val());
  708. console.log(edo)
  709. if((edo == 3 && valida()) || edo == 2){
  710. $("#formaModal").submit();
  711. }
  712. });
  713. });
  714. function validaFiltro(){
  715. if($('#filter_fecha_ini').val() != "" && !validaFecha($('#filter_fecha_ini').val()) ){
  716. $('#filter_fecha_ini').addClass("is-invalid");
  717. return false;
  718. }
  719. if($('#filter_fecha_fin').val() != "" && !validaFecha($('#filter_fecha_fin').val())){
  720. $('#filter_fecha_fin').addClass("is-invalid");
  721. return false;
  722. }
  723. if($('#filter_fecha_ini').val() != "" && $('#filter_fecha_fin').val() != "" && fechaMayor($('#filter_fecha_ini').val(), $('#filter_fecha_fin').val()) >= 0){
  724. $('#filter_fecha_fin').addClass("is-invalid");
  725. return false;
  726. }
  727. return true;
  728. }
  729. $(function() {
  730. $('[data-toggle="tooltip"]').tooltip()
  731. });
  732. /**@Auxiliary functions */
  733. function listProfesor({
  734. id,
  735. grado,
  736. profesor,
  737. clave
  738. }) {
  739. const lista = document.getElementById("dlProfesor");
  740. lista.innerHTML = "";
  741. lista.classList.remove("is-invalid");
  742. const li = document.createElement('li');
  743. li.setAttribute('data-id', id);
  744. li.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
  745. li.innerHTML = `${clave} | ${grado ?? ''} ${profesor}`
  746. const btn = document.createElement('button');
  747. btn.setAttribute('type', 'button');
  748. btn.classList.add('badge', 'badge-danger', 'badge-pill', 'border-0');
  749. btn.onclick = _ => li.remove();
  750. const i = document.createElement('i');
  751. i.classList.add('ing-cancelar');
  752. btn.appendChild(i);
  753. li.appendChild(btn);
  754. document.getElementById("profesores").appendChild(li);
  755. }
  756. function listSalon({
  757. id,
  758. nombre
  759. }) {
  760. const lista = document.getElementById("dlSalon");
  761. lista.innerHTML = "";
  762. lista.classList.remove("is-invalid");
  763. const li = document.createElement('li');
  764. li.setAttribute('data-id', id);
  765. li.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
  766. li.innerHTML = `${nombre}`
  767. const btn = document.createElement('button');
  768. btn.setAttribute('type', 'button');
  769. btn.classList.add('badge', 'badge-danger', 'badge-pill', 'border-0');
  770. btn.onclick = _ => li.remove();
  771. const i = document.createElement('i');
  772. i.classList.add('ing-cancelar');
  773. btn.appendChild(i);
  774. li.appendChild(btn);
  775. document.getElementById("salones").appendChild(li);
  776. }
  777. </script>
  778. </html>