reposiciones_autorizar.php 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764
  1. <?php
  2. require_once 'class/c_login.php';
  3. $user = Login::get_user();
  4. $user->access();
  5. //if (!$user->admin && in_array($user->acceso, ['n']))
  6. //die(header('Location: main.php?error=1'));
  7. $user->print_to_log('Reposiciones');
  8. //$write = $user->admin || in_array($user->acceso, ['w']);
  9. $write = true; //
  10. function duracionMinutos($fechahora_i, $fechahora_f){
  11. return round((strtotime($fechahora_f) - strtotime($fechahora_i)) / 60,2);
  12. }
  13. if(!empty($user->periodo)){
  14. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo])['esta_en_periodo'];
  15. $profesores_rs = array();
  16. $tab_inicial = 1;
  17. if($user->jefe_carrera){
  18. $carrera_rs = $db->query('SELECT * FROM fs_usuario_carrera(:usr, NULL)', [':usr'=>$user->user["id"]]);
  19. foreach($carrera_rs as $carr){
  20. $rs = $db->query('SELECT * FROM fs_profesor_carrera(:carr, :periodo)', [':carr' => $carr['carrera_id'], ':periodo' => $user->periodo]);
  21. $profesores_rs = array_merge($profesores_rs, $rs);
  22. }
  23. }else if($write){// $user->supervisor || $user->admin
  24. $profesores_rs = $db->query('SELECT * FROM fs_profesor_carrera(NULL, :periodo)', [':periodo' => $user->periodo]);
  25. $tab_inicial = 2;
  26. }else{
  27. die(header('Location: index.php'));
  28. }
  29. $salones_rs = $db->query('SELECT * FROM salon_view WHERE tiene_salones IS true');
  30. //Periodo
  31. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo]);
  32. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  33. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  34. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  35. else{
  36. $dias = 3;
  37. if( intval(date("w")) >=3 && intval(date("w"))<=5 )//Mie a Vie
  38. $dias+=3;
  39. else if( intval(date("w")) ==6 )//Sab
  40. $dias+=2;
  41. else if( intval(date("w")) ==0 )//Do
  42. $dias+=1;
  43. $fecha_man = date("d/m/Y", strtotime("+".$dias." day"));
  44. }
  45. // Fechas filtro
  46. if(isset($_POST["fecha_inicial"]))
  47. $fecha_ini = $_POST["fecha_inicial"];
  48. else
  49. $fecha_ini = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  50. if(isset($_POST["fecha_final"]))
  51. $fecha_fin = $_POST["fecha_final"];
  52. else
  53. $fecha_fin = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"]));
  54. //Reposiciones
  55. $repEdo_rs = $db->query('SELECT * FROM fs_estado_reposicion' );
  56. $repoParams = array();
  57. $query = "";//carrera, prof
  58. if($user->jefe_carrera){
  59. $query .= ":jefe, ";
  60. $repoParams[":jefe"] = $user->user["id"];
  61. }else{
  62. $query .= "NULL, ";
  63. }
  64. if((isset($_POST["prof"]) && is_numeric($_POST["prof"])) ){
  65. $query .= ":prof,";
  66. $repoParams[":prof"] = filter_input(INPUT_POST, "prof", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  67. }else{
  68. $query .= "NULL,";
  69. }
  70. $query .= ":f_ini, :f_fin, :edo, ";
  71. $repoParams[":f_ini"] = $fecha_ini;
  72. $repoParams[":f_fin"] = $fecha_fin;
  73. $repoParams[":edo"] = 1;//se sobreescribe
  74. }
  75. ?>
  76. <!DOCTYPE html>
  77. <html lang="en">
  78. <head>
  79. <title>Reposiciones autorizar | <?= $user->facultad['facultad'] ?? 'General' ?></title>
  80. <meta charset="utf-8">
  81. <meta http-equiv="content-type" content="text/plain; charset=UTF-8" />
  82. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  83. <?php include_once "import/html_css_files.php"; ?>
  84. <link rel="stylesheet" href="css/jquery-ui.css">
  85. <link rel="stylesheet" href="css/richtext.css" type="text/css">
  86. <link rel="stylesheet" href="css/clockpicker.css">
  87. <link rel="stylesheet" href="css/calendar.css">
  88. <link rel="stylesheet" href="css/fa_all.css" type="text/css">
  89. <script src="js/scrollables.js" defer></script>
  90. <script>
  91. const write = <?= $write ? 'true' : 'false' ?>;
  92. </script>
  93. <script src="js/moment.js" defer></script>
  94. <style>
  95. .wizard { height: 20px; width: 80%; background: #D0D0D0; }
  96. .wizard.full { background: #D0D0D0; }
  97. .wizard.active > div:first-child { background: #00A6CE; }
  98. .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); }
  99. </style>
  100. </head>
  101. <!-- -->
  102. <body style="display: block;">
  103. <?php
  104. include('include/constantes.php');
  105. include("import/html_header.php");
  106. html_header("Reposiciones de clase", "Sistema de gestión de checador");
  107. ?>
  108. <?= "<!-- $user -->" ?>
  109. <main class="container content marco content-margin" id="local-app">
  110. <section id="message"></section>
  111. <?php require('import/periodo.php') ?>
  112. <?php if(!empty($user->periodo)){ ?>
  113. <form id="asistencia" method="post" onsubmit="return validaFechas()">
  114. <div class="form-box">
  115. <input type="hidden" name="facultad" value="5">
  116. <div class="form-group row">
  117. <label for="filtro_inicial" class="col-4 col-form-label">Fecha inicial</label>
  118. <div class="col-8 col-sm-4">
  119. <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;?>">
  120. <div class="invalid-feedback">No es una fecha válida.</div>
  121. </div>
  122. </div>
  123. <div class="form-group row">
  124. <label for="filtro_final" class="col-4 col-form-label">Fecha final</label>
  125. <div class="col-8 col-sm-4">
  126. <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;?>">
  127. <div class="invalid-feedback">El rango de fechas no es válido.</div>
  128. </div>
  129. </div>
  130. <div class="form-group row">
  131. <label for="filtro_prof" class="col-4 col-form-label">Profesor</label>
  132. <div class="col-8 col-sm-4">
  133. <input list="lista_profesores" name="dlProfesor" id="dlProfesor" class="form-control" placeholder="Profesor">
  134. <div class="valid-feedback">
  135. Profesor encontrado
  136. </div>
  137. <div class="invalid-feedback">
  138. Profesor no encontrado
  139. </div>
  140. <datalist id="lista_profesores">
  141. <?php
  142. foreach ($profesores_rs as $profesor) {
  143. extract($profesor);
  144. ?>
  145. <option data-clave="<?= $profesor_clave ?>" data-profesor="<?= $profesor_nombre ?>" data-id="<?= $profesor_id; ?>" value="<?= "$profesor_clave | $profesor_nombre" ?>"></option>
  146. <?php
  147. }
  148. ?>
  149. </datalist>
  150. <ul class="list-group" id="profesores"></ul>
  151. <input type="hidden" id="editor_profesor" name="profesor" value="">
  152. </div>
  153. </div>
  154. </div>
  155. <div class="form-group row justify-content-center">
  156. <button type="submit" class="btn btn-outline-primary mr-2" id="btn-buscar"><span class="ing-buscar ing-fw"></span> Buscar</button>
  157. <button type="button" class="btn btn-outline-danger" onclick="window.location.href = window.location.href"><span class="ing-borrar ing-fw"></span> Limpiar</button>
  158. </div>
  159. </form>
  160. <ul class="nav nav-tabs d-print-none mb-4" id="myTab" role="tablist">
  161. <li class="nav-item">
  162. <a class="nav-link" id="tab1-tab" data-toggle="tab" href="#tab1" role="tab" aria-controls="calendario" aria-selected="true">Nuevas reposiciones</a>
  163. </li>
  164. <li class="nav-item">
  165. <a class="nav-link" id="tab2-tab" data-toggle="tab" href="#tab2" role="tab" aria-controls="lista" aria-selected="false">Aprobadas por jefe</a>
  166. </li>
  167. <li class="nav-item">
  168. <a class="nav-link" id="tab3-tab" data-toggle="tab" href="#tab3" role="tab" aria-controls="lista" aria-selected="false">Autorizadas</a>
  169. </li>
  170. <li class="nav-item">
  171. <a class="nav-link" id="tab4-tab" data-toggle="tab" href="#tab4" role="tab" aria-controls="lista" aria-selected="false">Rechazadas</a>
  172. </li>
  173. </ul>
  174. <div class="tab-content" id="TabContent">
  175. <?php
  176. $i=1;
  177. foreach($repEdo_rs as $redo){ ?>
  178. <div class="tab-pane fade" id="tab<?php echo $i;?>" role="tabpanel" aria-labelledby="tab<?php echo $i;?>-tab">
  179. <?php
  180. $repoParams[":edo"]=$redo["estado_reposicion_id"];
  181. $reposiciones_rs = $db->query('SELECT * FROM fs_reposicion(NULL, '.$query.'0, NULL) ', $repoParams );
  182. ?>
  183. <h4 class="mb-4" <?php echo "style='color:".$redo["estado_color"]."'>".$redo["estado_nombre"]; ?> </h4>
  184. <table class="table table-sm table-striped table-white">
  185. <thead class="thead-dark">
  186. <tr>
  187. <th>Estado</th>
  188. <th>Tipo</th>
  189. <th>Profesor/Materia</th>
  190. <th style="width:160px">Fecha falta</th>
  191. <th style="width:160px">Fecha reposición</th>
  192. <th>Salón</th>
  193. <?php if($write){ ?><th>Acciones</th><?php } ?>
  194. </tr>
  195. </thead>
  196. <tbody>
  197. <?php
  198. if(isset($reposiciones_rs)){
  199. foreach($reposiciones_rs as $reposicion){
  200. ?>
  201. <tr data-id="<?php echo $reposicion["reposicion_id"]; ?>" data-edo="<?php echo $reposicion["estado_reposicion_id"];?>" id="id<?php echo $reposicion["reposicion_id"]; ?>">
  202. <td class="align-middle">
  203. <?php if($reposicion["estado_reposicion_id"]<3){ ?>
  204. <div class="wizard <?php if(intval($reposicion["estado_reposicion_id"])==2) echo "active";?> d-flex mx-auto">
  205. <div class="w-50 h-100"></div>
  206. <div class=""></div>
  207. </div>
  208. <?php } else if($reposicion["estado_reposicion_id"]==3){?>
  209. <div class="text-success text-center pt-1">
  210. <span class="ing-autorizar ing-lg"></span>
  211. </div>
  212. <?php } else {?>
  213. <div class="text-danger text-center pt-1">
  214. <span class="ing-negar ing-lg"></span>
  215. </div>
  216. <?php } ?>
  217. </td>
  218. <td class="align-middle">
  219. <?php if($reposicion["es_reposicion"]) echo "Resposición"; else echo "Cambio"; ?>
  220. </td>
  221. <td><?php
  222. echo $reposicion["profesor_clave"]." - ".$reposicion["profesor_nombre"];
  223. ?>
  224. <br>
  225. <small>
  226. <?php echo $reposicion["materia_nombre"]; ?>
  227. (<?php
  228. echo $reposicion["horario_grupo"];
  229. ?>)
  230. </small>
  231. </td>
  232. <td class="text-center align-middle text-nowrap"><?php
  233. $fechaI = date("d/m/Y", strtotime($reposicion["fecha_clase"]));
  234. echo $fechaI."<br>".substr($reposicion["horario_hora"],0, 5);
  235. ?>
  236. </td>
  237. <td class="text-center align-middle text-nowrap"><?php
  238. $fechaF = date("d/m/Y", strtotime($reposicion["fecha_nueva"]));
  239. echo $fechaF."<br>".substr($reposicion["hora_nueva"],0, 5)." a ".substr($reposicion["hora_nueva_fin"],0, 5);
  240. ?>
  241. </td>
  242. <td class="text-center align-middle"><?php
  243. if($reposicion["salon_id"] != ""){
  244. echo $reposicion["salon_id"];
  245. }else
  246. echo "Pendiente";
  247. ?>
  248. </td>
  249. <?php if($write){ ?>
  250. <td class="text-center align-middle icono-acciones text-nowrap">
  251. <?php if (duracionMinutos($reposicion["fecha_nueva"], date("Y-m-d H:i:00")) < 0){ ?>
  252. <?php //no se cumple la fecha de la reposicion, es jefe de carrera
  253. if(($user->jefe_carrera || $user->admin) && $reposicion["estado_reposicion_id"] == 1){?>
  254. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="2" title="Aprobar"><?php echo $ICO["ver"];?></a>
  255. <?php } //no se cumple la fecha de la reposicion, no es jefe de carrera
  256. else if((!$user->jefe_carrera || $user->admin) && $reposicion["estado_reposicion_id"] >= 2){?>
  257. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="3" title="Autorizar" ><?php echo $ICO["ver"];?></a>
  258. <?php } else { ?>
  259. <a href="#" data-toggle="modal" data-target="#modal_aprobar" data-tipo="1" title="Aprobar"><?php echo $ICO["ver"];?></a>
  260. <?php } ?>
  261. <?php
  262. }else{ //fecha ya pasó?>
  263. <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>
  264. <?php } ?>
  265. <?php
  266. if($reposicion["estado_reposicion_id"]<4){
  267. if(
  268. (($user->jefe_carrera || $user->admin) && $reposicion["estado_reposicion_id"] <= 2)
  269. || ((!$user->jefe_carrera || $user->admin) && $reposicion["estado_reposicion_id"] >= 2 )){
  270. ?>
  271. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Cancelar"><span class="text-danger"><?php echo $ICO["cancelar"];?></span></a>
  272. <?php }
  273. } //estado
  274. ?>
  275. </td>
  276. <?php }//edición ?>
  277. </tr>
  278. <?php
  279. }//foreach
  280. }//if ?>
  281. </tbody>
  282. </table>
  283. </div>
  284. <?php
  285. $i++;
  286. } ?>
  287. </div>
  288. <!-- Modal -->
  289. <div class="modal fade" id="modal_aprobar" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  290. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  291. <div class="modal-content">
  292. <div class="modal-header">
  293. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Aprobar Reposición</span>
  294. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  295. <span aria-hidden="true">&times;</span>
  296. </button></h4>
  297. </div>
  298. <div class="modal-body">
  299. <form action="./action/reposicion_autoriza.php" method="post" id="formaModal">
  300. <input type="hidden" name="id" id="id">
  301. <input type="hidden" name="edo" id="edo" value="">
  302. <div class="row">
  303. <div class="col-6 col-sm-4 barra-right text-right">
  304. <p class="font-weight-bold">Profesor</p>
  305. </div>
  306. <div class="col-6">
  307. <p class="rep-prof"></p>
  308. </div>
  309. </div>
  310. <div class="row">
  311. <div class="col-6 col-sm-4 barra-right text-right">
  312. <p class="font-weight-bold">Materia</p>
  313. </div>
  314. <div class="col-6">
  315. <p class="rep-mat"></p>
  316. </div>
  317. </div>
  318. <div class="row">
  319. <div class="col-6 col-sm-4 barra-right text-right">
  320. <p class="font-weight-bold">Tipo</p>
  321. </div>
  322. <div class="col-6">
  323. <p class="rep-tipo"></p>
  324. </div>
  325. </div>
  326. <div class="row">
  327. <div class="col-6 col-sm-4 barra-right text-right">
  328. <p class="font-weight-bold">Fecha de falta</p>
  329. </div>
  330. <div class="col-6">
  331. <p class="rep-falta"></p>
  332. </div>
  333. </div>
  334. <div class="row">
  335. <div class="col-6 col-sm-4 barra-right text-right">
  336. <p class="font-weight-bold">Fecha de reposición</p>
  337. </div>
  338. <div class="col-6">
  339. <p class="rep-fecha"></p>
  340. </div>
  341. </div>
  342. <div class="row">
  343. <div class="col-6 col-sm-4 barra-right text-right">
  344. <p class="font-weight-bold">Alumnos aproximados</p>
  345. </div>
  346. <div class="col-6">
  347. <p class="rep-alumnos"></p>
  348. </div>
  349. </div>
  350. <div class="row">
  351. <div class="col-6 col-sm-4 barra-right text-right">
  352. <p class="font-weight-bold">Tipo de aula</p>
  353. </div>
  354. <div class="col-6">
  355. <p class="rep-aula"></p>
  356. </div>
  357. </div>
  358. <div class="row" id="salon-ver">
  359. <div class="col-6 col-sm-4 barra-right text-right">
  360. <p class="font-weight-bold">Salón</p>
  361. </div>
  362. <div class="col-6">
  363. <p class="rep-salon"></p>
  364. </div>
  365. </div>
  366. <div class="row" id="salon-editar" style="display: none;">
  367. <div class="col-6 col-sm-4 barra-right text-right">
  368. <p class="font-weight-bold">Salón *</p>
  369. </div>
  370. <div class="col-6">
  371. <input list="lista_salones" name="dlSalon" id="dlSalon" class="form-control" placeholder="Salón">
  372. <div class="valid-feedback">
  373. Salón encontrado
  374. </div>
  375. <div class="invalid-feedback">
  376. Salón no encontrado
  377. </div>
  378. <datalist id="lista_salones">
  379. <?php
  380. foreach ($salones_rs as $salon) {
  381. extract($salon);
  382. ?>
  383. <option data-id="<?= $salon_id ?>" data-nombre="<?= $salon ?>" value="<?= $salon ?>"></option>
  384. <?php
  385. }
  386. ?>
  387. </datalist>
  388. <ul class="list-group" id="salones"></ul>
  389. <input type="hidden" id="salon" name="salon" value="">
  390. </div>
  391. </div>
  392. <div class="row mt-4">
  393. <div class="col-6 col-sm-4 barra-right text-right">
  394. <p class="font-weight-bold">Comentarios</p>
  395. </div>
  396. <div class="col-6 bg-light">
  397. <p class="rep-comentarios"></p>
  398. </div>
  399. </div>
  400. <div class="form-group row mt-3">
  401. <div class="col-12 text-center">
  402. <p class="aprobar-block">Una vez realizada la acción no se puede deshacer.</p>
  403. <p>
  404. <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>
  405. <button type="button" class="btn btn-outline-secondary" data-dismiss="modal" aria-label="Close">Cerrar</button>
  406. </p>
  407. </div>
  408. </div>
  409. </form>
  410. </div>
  411. </div>
  412. </div>
  413. </div>
  414. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  415. <div class="modal-dialog modal-dialog-centered" role="document">
  416. <div class="modal-content">
  417. <div class="modal-body">
  418. <div class="row">
  419. <div class="col">
  420. <p class="font-weight-bold">¿Estás seguro de que quieres declinar la reposición?</p>
  421. <p>Esta acción no se puede deshacer.</p>
  422. </div>
  423. </div>
  424. <form action="./action/reposicion_autoriza.php" method="post">
  425. <div class="row">
  426. <div class="col-6 col-sm-4 barra-right text-right">
  427. <p class="font-weight-bold">Motivo</p>
  428. </div>
  429. <div class="col-6 col-sm-8">
  430. <textarea name="motivo" id="motivo" rows="3" class="form-control"></textarea>
  431. </div>
  432. </div>
  433. <div class="row">
  434. <div class="col-12 mt-4 text-center">
  435. <input type="hidden" id="id_borrar" name="id" value="">
  436. <input type="hidden" name="edo" value="4">
  437. <button type="submit" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Declinar</button>
  438. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cerrar</button>
  439. </div>
  440. </div>
  441. </form>
  442. </div>
  443. </div>
  444. </div>
  445. </div>
  446. <?php
  447. }
  448. ?>
  449. </main>
  450. </body>
  451. <script src="js/jquery.min.js"></script>
  452. <script src="js/bootstrap/popper.min.js"></script>
  453. <script src="js/bootstrap/bootstrap.min.js"></script>
  454. <script src="js/jquery-ui.js"></script>
  455. <script src="js/datepicker-es.js"></script>
  456. <script src="js/messages.js"></script>
  457. <?php
  458. //--Manejo de errores y mensajes de exito
  459. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  460. switch ($_GET["error"]){
  461. case 0: $errorDesc = "No se reciberon los datos de la reposición."; break;
  462. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la reposición/cambio."; break;
  463. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la reposición/cambio."; break;
  464. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  465. case 4: $errorDesc = "Ocurrió un error al cargar los datos de la reposición/cambio."; break;
  466. case 6: $errorDesc = "La reposición/cambio que buscas no existe. Consulta la lista de reopsiciones disponibles en esta sección."; break;
  467. case 7: $errorDesc = "La reposición/cambio se empalma con el horario del grupo y no se puede guardar."; break;
  468. 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;
  469. 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;
  470. case 10: $errorDesc = "El profesor está asigndo a una materia el mismo día a la misma hora y no se puede guardar."; break;
  471. case 11: $errorDesc = "No hay clases asignadas para esa materia y grupo en la fecha de falta."; break;
  472. }
  473. }
  474. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  475. switch ($_GET["ok"]){
  476. case 0: $successDesc = "La reposición se guardó correctamente."; break;
  477. case 1: $successDesc = "La reposición se actualizó correctamente."; break;
  478. }
  479. }
  480. require_once 'js/messages.php';
  481. ?>
  482. <script>
  483. <?php if(isset($errorDesc)){ ?>
  484. triggerMessage("<?php echo $errorDesc;?>", "Error");
  485. <?php } else if(isset($successDesc)){ ?>
  486. triggerMessage("<?php echo $successDesc;?>", "Éxito", "success");
  487. <?php } ?>
  488. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  489. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  490. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final };
  491. $(document).ready(function(){
  492. $(".date-picker-filtro" ).datepicker(datepickerOptions);
  493. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  494. $('#tab<?php echo $tab_inicial;?>-tab').tab('show');
  495. });
  496. function valida(){
  497. <?php
  498. if(!$user->jefe_carrera || $user->admin){ ?>
  499. $("#salon").removeClass("is-invalid");
  500. if($("#salon").val() === undefined || $("#salon").val() == 0 || $("#salon").val() == ''){
  501. $("#salon").addClass("is-invalid");
  502. return false;
  503. }
  504. <?php } ?>
  505. return true;
  506. }
  507. $(document).ready(function(){
  508. $('#modal_confirm').on('show.bs.modal', function (event) {
  509. var button = $(event.relatedTarget); // Button that triggered the modal
  510. var id = button.parents("tr").data("id");
  511. $("#id_borrar").val(id);
  512. $("#motivo").val("")
  513. });
  514. $('#modal_aprobar').on('show.bs.modal', function (event) {
  515. var button = $(event.relatedTarget); // Button that triggered the modal
  516. //console.log(button.data("tipo"));
  517. var id = button.parents("tr").data("id");
  518. var edo = button.data('tipo');
  519. $("#edo").val(edo);
  520. $("#id").val(id);
  521. $.ajax({
  522. url: './action/reposicion_select.php',
  523. type: 'POST',
  524. dataType: 'json',
  525. data: { id: id},
  526. success: function(result) {
  527. if(result["error"]!= "" && result["error"] !== undefined){
  528. triggerMessage(result["error"], "Error");
  529. $('#modal_aprobar').modal("hide");
  530. }else{
  531. $("#modal_aprobar .rep-prof").text(result["profesor_nombre"]);
  532. $("#modal_aprobar .rep-mat").text(result["materia_desc"]+" ["+result["grupo"]+"]" );
  533. if(result["tipo"])
  534. $("#modal_aprobar .rep-tipo").text("Reposición");
  535. else
  536. $("#modal_aprobar .rep-tipo").text("Cambio");
  537. $("#modal_aprobar .rep-aula").text(result["aula_desc"])
  538. $("#modal_aprobar .rep-aula").data("aula",result["aula"]);
  539. $("#modal_aprobar .rep-falta").text(result["fecha_clase"]);
  540. $("#modal_aprobar .rep-fecha").text(result["fecha_nueva"]+" de "+result["hora_ini"]+":"+result["min_ini"]+" a "+result["hora_fin"]+":"+result["min_fin"]);
  541. if(result["salon"] =="" || result["salon"] === undefined){
  542. $('#salon').prop("selectedIndex", 0);
  543. }else{
  544. $('#salon').val(result["salon"]);
  545. }
  546. $("#modal_aprobar .rep-salon").text(result["salon_desc"]);
  547. $("#modal_aprobar .rep-comentarios").text(result["comentario"]);
  548. $('#modal_aprobar .rep-alumnos').text(result["alumnos"]);
  549. if(button.data("tipo") == 1){//ver
  550. $("#modalLabel").text("Detalle de reposición");
  551. $(".aprobar-block").hide();
  552. $("#salon-ver").show();
  553. $("#salon-editar").hide();
  554. }else{
  555. if(parseInt($("#modal_aprobar .rep-aula").data("aula")) == 1){//ver
  556. $("#modalLabel").text("Detalle de reposición");
  557. $(".aprobar-block").hide();
  558. $("#salon-ver").show();
  559. $("#salon-editar").hide();
  560. }else{
  561. $("#modalLabel").text("Aprobar reposición");
  562. $(".aprobar-block").show();
  563. if(button.data("tipo") == 3){//aprobar (con salón)
  564. $("#salon-ver").hide();
  565. $("#salon-editar").show();
  566. }
  567. }
  568. }
  569. if(result["aula_supervisor"]){//Solo supervisor
  570. <?php if($user->supervisor){ ?>
  571. $("#salon-editar").attr("disabled", false);
  572. <?php }else{?>
  573. $("#salon-editar").attr("disabled", true);
  574. <?php } ?>
  575. }else{// Facultad
  576. <?php if(!$user->supervisor){ ?>
  577. $("#salon-editar").attr("disabled", false);
  578. <?php }else{?>
  579. $("#salon-editar").attr("disabled", true);
  580. <?php } ?>
  581. }
  582. }
  583. },
  584. error: function(jqXHR, textStatus, errorThrown ){
  585. triggerMessage(errorThrown, "Error");
  586. }
  587. });//ajax
  588. });
  589. /*
  590. $(".btn-borrar").click(function(){
  591. var cid = $("#id_borrar").val();
  592. $.ajax({
  593. url: './action/reposicion_autoriza.php',
  594. type: 'POST',
  595. dataType: 'json',
  596. data: { id: cid, edo: 4},
  597. success: function(result) {
  598. if(result["error"]!= "" && result["error"] !== undefined){
  599. $("#errorBox").collapse('show');
  600. $("#errorBox_text").html(result["error"]);
  601. }else{
  602. $("#successBox").collapse('show');
  603. $("#successBox_text").html(result["ok"]);
  604. $("#id"+cid).remove();
  605. }
  606. $('#messageBox')[0].scrollIntoView({ block: "end" });
  607. },
  608. error: function(jqXHR, textStatus, errorThrown ){
  609. $("#errorBox").collapse('show');
  610. $("#errorBox_text").html(errorThrown);
  611. $('#messageBox')[0].scrollIntoView({ block: "end" });
  612. }
  613. });//ajax
  614. $('#modal_confirm').modal("hide");
  615. });*/
  616. $("#submitBtn").click(function(){
  617. var edo = parseInt($("#edo").val());
  618. console.log(edo)
  619. if((edo == 3 && valida()) || edo == 2){
  620. $("#formaModal").submit();
  621. }
  622. });
  623. });
  624. function validaFiltro(){
  625. if($('#filter_fecha_ini').val() != "" && !validaFecha($('#filter_fecha_ini').val()) ){
  626. $('#filter_fecha_ini').addClass("is-invalid");
  627. return false;
  628. }
  629. if($('#filter_fecha_fin').val() != "" && !validaFecha($('#filter_fecha_fin').val())){
  630. $('#filter_fecha_fin').addClass("is-invalid");
  631. return false;
  632. }
  633. if($('#filter_fecha_ini').val() != "" && $('#filter_fecha_fin').val() != "" && fechaMayor($('#filter_fecha_ini').val(), $('#filter_fecha_fin').val()) >= 0){
  634. $('#filter_fecha_fin').addClass("is-invalid");
  635. return false;
  636. }
  637. return true;
  638. }
  639. $(function() {
  640. $('[data-toggle="tooltip"]').tooltip()
  641. });
  642. /**@Auxiliary functions */
  643. function listProfesor({
  644. id,
  645. grado,
  646. profesor,
  647. clave
  648. }) {
  649. const lista = document.getElementById("dlProfesor");
  650. lista.innerHTML = "";
  651. lista.classList.remove("is-invalid");
  652. const li = document.createElement('li');
  653. li.setAttribute('data-id', id);
  654. li.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
  655. li.innerHTML = `${clave} | ${grado ?? ''} ${profesor}`
  656. const btn = document.createElement('button');
  657. btn.setAttribute('type', 'button');
  658. btn.classList.add('badge', 'badge-danger', 'badge-pill', 'border-0');
  659. btn.onclick = _ => li.remove();
  660. const i = document.createElement('i');
  661. i.classList.add('ing-cancelar');
  662. btn.appendChild(i);
  663. li.appendChild(btn);
  664. document.getElementById("profesores").appendChild(li);
  665. }
  666. function listSalon({
  667. id,
  668. nombre
  669. }) {
  670. const lista = document.getElementById("dlSalon");
  671. lista.innerHTML = "";
  672. lista.classList.remove("is-invalid");
  673. const li = document.createElement('li');
  674. li.setAttribute('data-id', id);
  675. li.classList.add('list-group-item', 'd-flex', 'justify-content-between', 'align-items-center');
  676. li.innerHTML = `${nombre}`
  677. const btn = document.createElement('button');
  678. btn.setAttribute('type', 'button');
  679. btn.classList.add('badge', 'badge-danger', 'badge-pill', 'border-0');
  680. btn.onclick = _ => li.remove();
  681. const i = document.createElement('i');
  682. i.classList.add('ing-cancelar');
  683. btn.appendChild(i);
  684. li.appendChild(btn);
  685. document.getElementById("salones").appendChild(li);
  686. }
  687. </script>
  688. </html>