reposiciones_crear.php 51 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934
  1. <?php
  2. require_once 'class/c_login.php';
  3. $user = Login::get_user();
  4. print_r($user);
  5. print_r($user->profesor);
  6. print_r($user->acceso);//null sin permisos, w o r
  7. //profesor, admin, rol, facultad
  8. if (!$user->profesor && !$user->admin){
  9. die(header('Location: index.php'));
  10. }
  11. //if (!$user->admin && in_array($user->acceso, ['n']))
  12. //die(header('Location: main.php?error=1'));
  13. $user->print_to_log('Reposiciones');
  14. //$write = $user->admin || in_array($user->acceso, ['w']);
  15. $write = true; //
  16. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo_id])['esta_en_periodo'];
  17. $prof_rs = $db->query('SELECT * FROM profesor A WHERE EXISTS (
  18. SELECT * FROM horario_view hv join HORARIO_PROFESOR ON hv.HORARIO_ID = HORARIO_PROFESOR.horario_id WHERE HORARIO_PROFESOR.profesor_id = A.profesor_id AND hv.periodo_id = :periodo_id
  19. ) ORDER BY profesor_nombre', [':periodo_id' => $user->periodo_id]);
  20. //Periodo
  21. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo_id]);
  22. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  23. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  24. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  25. else{
  26. $dias = 3;
  27. if( intval(date("w")) >=3 && intval(date("w"))<=5 )//Mie a Vie
  28. $dias+=3;
  29. else if( intval(date("w")) ==6 )//Sab
  30. $dias+=2;
  31. else if( intval(date("w")) ==0 )//Do
  32. $dias+=1;
  33. $fecha_man = date("d/m/Y", strtotime("+".$dias." day"));
  34. }
  35. // Materias
  36. $id_prof = $user->user["id"];
  37. //$facultad_id = 28;
  38. $materias_rs = $db->query('SELECT * FROM fs_materiasprofesor(:id)', [':id' => $id_prof]);
  39. if(isset($_POST["fecha_inicial"]))
  40. $fecha_ini = $_POST["fecha_inicial"];
  41. else
  42. $fecha_ini = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  43. if(isset($_POST["fecha_final"]))
  44. $fecha_fin = $_POST["fecha_final"];
  45. else
  46. $fecha_fin = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"]));
  47. $fecha_ini_db= date("Y-m-d", strtotime($fecha_ini));
  48. $fecha_fin_db= date("Y-m-d", strtotime($fecha_fin));
  49. ?>
  50. <!DOCTYPE html>
  51. <html lang="en">
  52. <head>
  53. <title>Reposiciones crear | <?= $user->facultad['facultad'] ?? 'General' ?></title>
  54. <meta charset="utf-8">
  55. <meta http-equiv="content-type" content="text/plain; charset=UTF-8" />
  56. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  57. <?php include_once "import/html_css_files.php"; ?>
  58. <link rel="stylesheet" href="css/jquery-ui.css">
  59. <link rel="stylesheet" href="css/richtext.css" type="text/css">
  60. <link rel="stylesheet" href="css/clockpicker.css">
  61. <link rel="stylesheet" href="css/calendar.css">
  62. <link rel="stylesheet" href="css/fa_all.css" type="text/css">
  63. <script src="js/scrollables.js" defer></script>
  64. <script>
  65. const write = <?= $write ? 'true' : 'false' ?>;
  66. </script>
  67. <script src="js/moment.js" defer></script>
  68. <style>
  69. .wizard { height: 20px; width: 80%; background: #D0D0D0; }
  70. .wizard.full { background: #D0D0D0; }
  71. .wizard.active > div:first-child { background: #00A6CE; }
  72. .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); }
  73. </style>
  74. <script src="js/jquery.min.js"></script>
  75. <script src="js/bootstrap/popper.min.js"></script>
  76. <script src="js/bootstrap/bootstrap.min.js"></script>
  77. <script src="js/jquery-ui.js"></script>
  78. <script src="js/datepicker-es.js"></script>
  79. </head>
  80. <!-- -->
  81. <body style="display: block;">
  82. <?php
  83. include('include/constantes.php');
  84. include("import/html_header.php");
  85. html_header("Reposiciones de clase", "Sistema de gestión de checador");
  86. ?>
  87. <main class="container content marco content-margin" id="local-app">
  88. <?php if($write==true ) {?>
  89. <!-- Botón para abrir el modal -->
  90. <div class="row mb-4">
  91. <div class="col-12 text-right">
  92. <button type="button" class="btn btn-outline-secondary" data-tipo="1" data-toggle="modal" data-target="#modal" <?php if (!$en_fecha || (empty($materias_rs) || count($materias_rs)==0 ) ){ echo "disabled"; } ?>><span class="ing-mas ing-fw"></span>Crear reposición</button>
  93. </div>
  94. </div>
  95. <?php }?>
  96. <section id="message"></section>
  97. <?php require('import/periodo.php') ?>
  98. <form id="asistencia" method="post" onsubmit="return validaFechas()">
  99. <div class="form-box">
  100. <input type="hidden" name="facultad" value="">
  101. <div class="form-group row">
  102. <label for="filtro_inicial" class="col-4 col-form-label">Fecha inicial</label>
  103. <div class="col-8 col-sm-4">
  104. <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;?>">
  105. <div class="invalid-feedback">No es una fecha válida.</div>
  106. </div>
  107. </div>
  108. <div class="form-group row">
  109. <label for="filtro_final" class="col-4 col-form-label">Fecha final</label>
  110. <div class="col-8 col-sm-4">
  111. <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;?>">
  112. <div class="invalid-feedback">El rango de fechas no es válido.</div>
  113. </div>
  114. </div>
  115. </div>
  116. <div class="form-group row justify-content-center">
  117. <button type="submit" class="btn btn-outline-primary mr-2" id="btn-buscar"><span class="ing-buscar ing-fw"></span> Buscar</button>
  118. <button type="button" class="btn btn-outline-danger" onclick="window.location.href = window.location.href"><span class="ing-borrar ing-fw"></span> Limpiar</button>
  119. </div>
  120. </form>
  121. <?php
  122. $reposiciones_rs = $db->query('SELECT * FROM fs_reposicionesprofesor(:f_ini, :f_fin, NULL, NULL)', [':f_ini' => $fecha_ini_db, ':f_fin' => $fecha_fin_db]);
  123. ?>
  124. <div class="row">
  125. <?php
  126. if(isset($reposiciones_rs) && count($reposiciones_rs)>0){ ?>
  127. <h3 class="mb-3">Mis reposiciones</h3>
  128. <div class="col-12 table-responsive px-0">
  129. <table class="table table-sm table-striped table-white">
  130. <thead class="thead-dark">
  131. <tr >
  132. <th>Estado</th>
  133. <th>Materia</th>
  134. <th>Tipo</th>
  135. <th style="width:160px">Fecha falta</th>
  136. <th style="width:160px">Fecha reposición</th>
  137. <th>Salón</th>
  138. <?php if($write){ ?><th>Acciones</th><?php } ?>
  139. </tr>
  140. </thead>
  141. <tbody>
  142. <?php
  143. foreach($reposiciones_rs as $reposicion){
  144. ?>
  145. <tr data-id="<?php echo $reposicion["reposicion_id"]; ?>" id="id<?php echo $reposicion["reposicion_id"]; ?>">
  146. <td class="align-middle text-center" style="color:<?php echo $reposicion["estado_color"];?>" title="<?php echo $reposicion["estado_nombre"];?>">
  147. <?php if($reposicion["estado_reposicion_id"]<3){ ?>
  148. <div class="wizard <?php if(intval($reposicion["estado_reposicion_id"])==2) echo "active";?> d-flex mx-auto">
  149. <div class="w-50 h-100"></div>
  150. <div class=""></div>
  151. </div>
  152. <?php } else if($reposicion["estado_reposicion_id"]==3){?>
  153. <div class="text-success text-center pt-1">
  154. <span class="ing-autorizar ing-lg"></span>
  155. </div>
  156. <?php } else {?>
  157. <div class="text-danger text-center pt-1">
  158. <span class="ing-negar ing-lg"></span>
  159. </div>
  160. <?php } ?>
  161. </td>
  162. <td class="align-middle"><?php echo $reposicion["materia_nombre"]; ?></td>
  163. <td class="align-middle">
  164. <?php if($reposicion["es_reposicion"]) echo "Reposición"; else echo "Cambio"; ?>
  165. </td>
  166. <td class="align-middle text-center"><?php
  167. echo date("d/m/Y", strtotime($reposicion["fecha_clase"]));
  168. ?>
  169. </td>
  170. <td class="align-middle text-center"><?php
  171. echo date("d/m/Y", strtotime($reposicion["fecha_nueva"])) ."<br>".substr($reposicion["hora_nueva"],0,-3)." a ".substr($reposicion["hora_nueva_fin"],0,-3)." hrs.";
  172. ?>
  173. </td>
  174. <td class="align-middle text-center"><?php
  175. if($reposicion["salon_id"] != ""){
  176. echo $reposicion["salon_id"];
  177. }else
  178. echo "Pendiente";
  179. ?>
  180. </td>
  181. <?php if($write){ ?>
  182. <td class="align-middle text-center icono-acciones">
  183. <?php
  184. //no se ha aprobado
  185. if($reposicion["estado_reposicion_id"] == 1){?>
  186. <a href="#" data-tipo="2" title="Editar" data-toggle="modal" data-target="#modal"><?php echo $ICO["editar"];?></a>
  187. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Borrar"><?php echo $ICO["cancelar"];?></a>
  188. <?php } ?>
  189. </td>
  190. <?php } ?>
  191. </tr>
  192. <?php }
  193. ?>
  194. </tbody>
  195. </table>
  196. </div>
  197. <?php } else { ?>
  198. <div class="col-12 text-center">
  199. <h4 class="mt-4 text-danger">No tienes reposiciones disponibles que cumplan con los filtros</h4>
  200. </div>
  201. <?php } ?>
  202. </div>
  203. <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  204. <div class="modal-dialog modal-dialog-centered modal-xl" role="document">
  205. <div class="modal-content">
  206. <div class="modal-header">
  207. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Crear Reposición</span>
  208. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  209. <span aria-hidden="true">&times;</span>
  210. </button></h4>
  211. </div>
  212. <div class="modal-body">
  213. <form action="./action/reposicion_insert.php" method="post" id="formaModal" onsubmit="return submitForm()">
  214. <input type="hidden" name="id" id="id">
  215. <input type="hidden" name="estado" value="1">
  216. <div class="form-box">
  217. <div class="form-group row <?php if(true){ echo "d-none"; }?>" id="profBlock">
  218. <label for="prof" class="col-4 col-form-label">Profesor *</label>
  219. <div class="col-8">
  220. <div class="datalist datalist-select mb-1 w-100" id="dlProfesor">
  221. <div class="datalist-input">Profesores del área</div>
  222. <span class="ing-buscar icono"></span>
  223. <ul style="display:none">
  224. <?php foreach($prof_rs as $prof){?>
  225. <li data-id="<?php echo $prof["id"];?>" <?php if($prof["id"]==$_SESSION["usuario_id"]){ echo "class='selected'";} ?> ><?php echo $prof["profesor"];?></li>
  226. <?php } ?>
  227. </ul>
  228. <input type="hidden" id="prof" name="prof" value="<?php echo $id_prof;?>">
  229. </div>
  230. </div>
  231. </div>
  232. <div class="form-group row" id="materiaBlock">
  233. <label for="horario" class="col-4 col-form-label">Materia *</label>
  234. <div class="col-8">
  235. <div class="datalist datalist-select mb-1 w-100" id="dlMateria">
  236. <div class="datalist-input">Selecciona una materia</div>
  237. <span class="ing-buscar icono"></span>
  238. <ul style="display:none">
  239. <?php foreach($materias_rs as $mat){ ?>
  240. <li data-id="<?php echo $mat["horario_id"];?>" data-dia="<?php echo $mat["horario_dia"];?>" data-hr="<?php echo substr($mat["horario_hora"], 0, 2);?>" data-min="<?php echo substr($mat["horario_hora"], 3, 2);?>">
  241. <?php echo $mat["materia_nombre"].' - '.$mat["horario_dia_nombre"]." ".substr($mat["horario_hora"], 0, -3);?>
  242. </li>
  243. <?php } ?>
  244. </ul>
  245. <input type="hidden" id="horario" name="horario" value="">
  246. </div>
  247. </div>
  248. </div>
  249. <div class="form-group row">
  250. <label for="tipo" class="col-4 col-form-label">Tipo *</label>
  251. <div class="col-8">
  252. <div class="datalist datalist-select mb-1 w-100" id="dlTipo">
  253. <div class="datalist-input">Reposición</div>
  254. <span class="ing-buscar icono"></span>
  255. <ul style="display:none">
  256. <li data-id="1">Reposición</li>
  257. <li data-id="2">Cambio de salón</li>
  258. </ul>
  259. <input type="hidden" id="tipo" name="tipo" value="1">
  260. </div>
  261. </div>
  262. </div>
  263. <div class="form-group row cambio_block materia-block" style="display: none;">
  264. <label for="fecha_cambio" class="col-4 col-form-label">Fecha de cambio *</label>
  265. <div class="col-8">
  266. <input id="fecha_cambio" name="fecha_cambio" type="text" class="form-control date-picker" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="readonly" value="">
  267. </div>
  268. </div>
  269. <div class="form-group row repo_block materia-block">
  270. <label for="fecha_falta" class="col-4 col-form-label">Fecha de falta *</label>
  271. <div class="col-8">
  272. <input id="fecha_falta" name="fecha_falta" type="text" class="form-control date-picker" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="readonly" value="">
  273. </div>
  274. </div>
  275. <div class="form-group row repo_block materia-block">
  276. <label for="fecha_inicial" class="col-4 col-form-label">Fecha de reposicion *</label>
  277. <div class="col-8">
  278. <input id="fecha_inicial" name="fecha_inicial" type="text" class="form-control date-picker-future" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="readonly" value="">
  279. <small class="form-text text-muted">Las reposiciones se deben solicitar con al menos 72hrs de anticipación.<br>
  280. Si repones en sábado, consulta los horarios con tu jefe de carrera.
  281. </small>
  282. </div>
  283. </div>
  284. <div class="form-group row materia-block">
  285. <label for="hora_ini" class="col-4 col-form-label" id="hora_nombre">Hora reposición *</label>
  286. <?php
  287. //define("HORA_FINAL", 22);
  288. //define("FRACCION_HORA", 15);
  289. $default_h = 7; $default_m = 15;
  290. ?>
  291. <div class="col-4">
  292. <select name="hora_ini" id="hora_ini" class="form-control" required="required">
  293. <?php for($h = $default_h; $h < HORA_FINAL; $h++){?>
  294. <option value="<?php echo sprintf( '%02d', $h );?>" <?php if($default_h == $h){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $h );?></option>
  295. <?php } ?>
  296. </select>
  297. </div>
  298. <div class="col-4">
  299. <select name="min_ini" id="min_ini" class="form-control" required="required">
  300. <?php for($m = 0; $m < 60; $m+=(60/FRACCION_HORA)){?>
  301. <option value="<?php echo sprintf( '%02d', $m );?>" <?php if($default_m == $m){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $m );?></option>
  302. <?php } ?>
  303. </select>
  304. </div>
  305. </div>
  306. <div class="form-group row materia-block">
  307. <label for="salon" class="col-4 col-form-label">Alumnos aproximados *</label>
  308. <div class="col-8 col-md-4">
  309. <input type="number" name="alumnos" id="alumnos" class="form-control" value="1" min="1" max="50">
  310. </div>
  311. </div>
  312. <div class="form-group row materia-block">
  313. <label for="aula" class="col-4 col-form-label">Tipo aula *</label>
  314. <div class="col-8">
  315. <div class="datalist datalist-select mb-1 w-100" id="dlAula">
  316. <div class="datalist-input">Salón</div>
  317. <span class="ing-buscar icono"></span>
  318. <ul style="display:none">
  319. <li data-id="1">Salón</li>
  320. <li data-id="2">Sala de cómputo</li>
  321. <li data-id="3">Salón/Taller de la facultad</li>
  322. </ul>
  323. <input type="hidden" id="aula" name="aula" value="1">
  324. </div>
  325. </div>
  326. </div>
  327. </div>
  328. <div class="form-box form-box-info materia-block">
  329. <div class="form-group row">
  330. <label for="comentario" class="col-4 col-form-label">Comentarios</label>
  331. <div class="col-8">
  332. <p><i>Requerimientos específicos del salón, software especializado, etc.</i></p>
  333. <textarea rows="3" class="form-control" id="comentario" name="comentario"></textarea>
  334. </div>
  335. </div>
  336. </div>
  337. <div class="form-group row mt-3">
  338. <div class="offset-4 col-8">
  339. <button type="submit" class="btn btn-outline-primary materia-block" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  340. <button type="reset" class="btn btn-outline-danger" data-dismiss="modal"><?php echo $ICO["cancelar"];?> Cancelar</button>
  341. </div>
  342. </div>
  343. </form>
  344. </div>
  345. </div>
  346. </div>
  347. </div>
  348. <!-- Modal del formulario -->
  349. <div class="modal fade" id="crearReposiciónOld" tabindex="-1" role="dialog" aria-labelledby="crearReposiciónLabel" aria-hidden="true">
  350. <div class="modal-dialog modal-xl" role="document">
  351. <div class="modal-content">
  352. <div class="modal-header">
  353. <h5 class="modal-title" id="crearReposiciónLabel">Crear Reposición</h5>
  354. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  355. <span aria-hidden="true">&times;</span>
  356. </button>
  357. </div>
  358. <div class="modal-body">
  359. <form id="form" class="form-horizontal">
  360. <div class="form-group step" id="step-1">
  361. <div class="form-box">
  362. <div class="form-group row">
  363. <label for="clave_profesor" class="col-4 col-form-label">Profesor</label>
  364. <div class="col-8">
  365. <input list="lista_profesores" name="clave_profesor" id="clave_profesor" class="form-control" placeholder="Profesor" required="required">
  366. <div class="valid-feedback">
  367. Profesor encontrado
  368. </div>
  369. <div class="invalid-feedback">
  370. Profesor no encontrado
  371. </div>
  372. <datalist id="lista_profesores">
  373. <?php
  374. foreach ($prof_rs as $prof) {
  375. ?>
  376. <option data-grado="<?= $prof["profesor_grado"] ?>" data-clave="<?= $prof["profesor_clave"] ?>" data-profesor="<?= $prof["profesor_nombre"] ?>" data-id="<?= $prof["profesor_id"]; ?>" value="<?= "{$prof["profesor_clave"]} | {$prof["profesor_grado"]} {$prof["profesor_nombre"]}" ?>"></option>
  377. <?php
  378. }
  379. ?>
  380. </datalist>
  381. <ul class="list-group" id="profesores"></ul>
  382. <input type="hidden" id="periodo_id" name="periodo_id" value="<?= $user->periodo_id ?>">
  383. <input type="hidden" id="profesor_id" name="profesor_id" value="">
  384. </div>
  385. </div>
  386. </div>
  387. </div>
  388. <div class="form-group step" id="step-2">
  389. <div class="form-box">
  390. <div class="form-group row">
  391. <label for="horario_reponer" class="col-4 col-form-label">Horario a reponer</label>
  392. <div class="col-8">
  393. <select name="horario_reponer" id="horario_reponer" class="form-control" required="required">
  394. </select>
  395. </div>
  396. </div>
  397. </div>
  398. <input type="hidden" name="horario_id" id="horario_id">
  399. </div>
  400. <div class="form-group step" id="step-3">
  401. <div class="form-box">
  402. <div class="form-group row">
  403. <label for="fechas_clase" class="col-4 col-form-label">Fecha de clase</label>
  404. <div class="col-8">
  405. <select name="fechas_clase" id="fechas_clase" class="form-control" required="required">
  406. </select>
  407. </div>
  408. </div>
  409. </div>
  410. </div>
  411. <div class="form-group step" id="step-4">
  412. <div class="form-box">
  413. <div class="form-group row">
  414. <label for="fecha_reponer" class="col-4 col-form-label">Fecha de reposición</label>
  415. <div class="col-6">
  416. <input type="text" placeholder="dd/mm/aaaa" name="fecha_reponer" id="fecha_reponer" class="form-control date-picker" required="required">
  417. </div>
  418. </div>
  419. <div class="form-group row">
  420. <label for="hora" class="col-4 col-form-label">Hora</label>
  421. <div class="col-3">
  422. <div id="hora" class="datalist datalist-select mb-1">
  423. <div class="datalist-input text-center">hh</div>
  424. <span class="ing-buscar icono"></span>
  425. <ul style="display:none">
  426. <?php foreach (range(7, 21) as $hora) { ?>
  427. <li data-id='<?= $hora ?>'><?= str_pad($hora, 2, "0", STR_PAD_LEFT) ?></li>
  428. <?php } ?>
  429. </ul>
  430. <input type="hidden" id="hora_reponer" name="horas" value="">
  431. </div>
  432. </div>
  433. <div class="col-3">
  434. <div id="minutos" class="datalist datalist-select mb-1">
  435. <div class="datalist-input text-center">mm</div>
  436. <span class="ing-buscar icono"></span>
  437. <ul style="display:none">
  438. <?php foreach (range(0, 45, 15) as $minuto) { ?>
  439. <li data-id='<?= $minuto ?>'><?= str_pad($minuto, 2, "0", STR_PAD_LEFT) ?></li>
  440. <?php } ?>
  441. </ul>
  442. <input type="hidden" id="minutos_reponer" name="minutos" value="">
  443. </div>
  444. </div>
  445. </div>
  446. </div>
  447. </div>
  448. <div class="form-group step" id="step-5">
  449. <div class="form-box">
  450. <div class="form-group row">
  451. <label for="descripcion_reposicion" class="col-4 col-form-label">Comentarios</label>
  452. <div class="col-6">
  453. <textarea name="descripcion_reposicion" id="descripcion_reposicion" rows="4" required="required" placeholder="Se requiere proyector, etc." maxlength="255" class="form-control"></textarea>
  454. </div>
  455. </div>
  456. <div class="form-group row align-items-center">
  457. <label class="col-4 col-form-label" for="sala">¿En sala de cómputo?</label>
  458. <div class="col-6">
  459. <div class="custom-control custom-switch">
  460. <input type="checkbox" class="custom-control-input" id="sala">
  461. <label class="custom-control-label" for="sala"></label>
  462. </div>
  463. </div>
  464. </div>
  465. </div>
  466. </div>
  467. </form>
  468. </div>
  469. <div class="modal-footer justify-content-center">
  470. <button class="btn btn-secondary" type="button" id="prev-button">Anterior</button>
  471. <button class="btn btn-secondary" type="button" id="next-button" disabled data-toggle="modal" data-target="#confirmationModal">Proponer reposición</button>
  472. </div>
  473. <!-- Modal confirmación -->
  474. <div class="modal fade" id="confirmationModal" tabindex="-1" role="dialog" aria-labelledby="confirmationModalLabel" aria-hidden="true">
  475. <div class="modal-dialog modal-sm" role="document">
  476. <div class="modal-content">
  477. <div class="modal-header">
  478. <h5 class="modal-title" id="confirmationModalLabel">Confirmación</h5>
  479. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  480. <span aria-hidden="true">&times;</span>
  481. </button>
  482. </div>
  483. <div class="modal-body">
  484. <p>¿Estás seguro de que deseas proponer la reposición?</p>
  485. <small>Recuerda que la aprobará tu jefe de carrera.</small>
  486. </div>
  487. <div class="modal-footer">
  488. <button type="button" class="btn btn-info" onclick="$('#confirmationModal').modal('hide');">Cancelar</button>
  489. <button type="button" class="btn btn-primary" data-dismiss="modal">Aceptar</button>
  490. </div>
  491. </div>
  492. </div>
  493. </div>
  494. </div>
  495. </div>
  496. </div>
  497. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  498. <div class="modal-dialog modal-dialog-centered" role="document">
  499. <div class="modal-content">
  500. <div class="modal-body">
  501. <div class="row">
  502. <div class="col">
  503. <p class="font-weight-bold">¿Estás seguro de que quieres borrar la reposición?</p>
  504. <p>Esta acción no se puede deshacer.</p>
  505. </div>
  506. </div>
  507. </div>
  508. <div class="modal-footer">
  509. <input type="hidden" id="id_borrar" value="">
  510. <button type="button" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Borrar</button>
  511. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  512. </div>
  513. </div>
  514. </div>
  515. </div>
  516. </main>
  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 vacaciones=[
  549. <?php /*foreach($vacacionesArr as $v){ echo '"'.$v["fecha"].'",';}*/ ?>
  550. ];
  551. var _dias_asistencia = [];//ya registró asistencia, cambia con ajax
  552. var _dia_valido = 0;
  553. var _fecha_manhana = "<?php echo $fecha_man; ?>";
  554. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  555. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  556. var datepickerOptions_filtro = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final};
  557. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final,
  558. beforeShowDay: function(date) {
  559. var day = date.getDay();
  560. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  561. if (day === _dia_valido) {// 0 representa el domingo
  562. if (vacaciones.indexOf(dateString) !== -1 || _dias_asistencia.indexOf(dateString) !== -1)
  563. return [false];
  564. else
  565. return [true];
  566. }else{
  567. return [false];
  568. }
  569. }
  570. };
  571. var datepickerOptions_future = { dateFormat: "dd/mm/yy", minDate:_fecha_manhana, maxDate:_periodo_fecha_final,
  572. beforeShowDay: function(date) {
  573. var day = date.getDay();
  574. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  575. if (day === 0) {// 0 representa el domingo
  576. return [false];
  577. } else {
  578. if (vacaciones.indexOf(dateString) !== -1) {
  579. return [false];
  580. } else {
  581. return [true];
  582. }
  583. }
  584. }
  585. };
  586. function diaAAno(fecha_str){//de dd/mm/yyyy a yyyy-mm-dd
  587. if(fecha_str.charAt(2) == "/" && fecha_str.charAt(5) == "/"){//dd/mm/yyyy
  588. var fecha_arr = fecha_str.split("/");
  589. return fecha_arr[2]+"-"+fecha_arr[1]+"-"+fecha_arr[0];
  590. }
  591. return fecha_str;
  592. }
  593. function fechaMayor(fechaI, fechaF) {//cual es mayor >0 I mayor <0 F mayor
  594. return (Date.parse(diaAAno(fechaI)) - Date.parse(diaAAno(fechaF)));
  595. }
  596. function validaFechas(){
  597. if(fechaMayor($('#filtro_inicial').val().trim(), $('#filtro_final').val().trim()) > 0){
  598. $('#filtro_final').addClass("is-invalid");
  599. return false;
  600. }
  601. return true;
  602. }
  603. function submitForm(){
  604. var myBtn = $('#submitBtn');
  605. var error = false;
  606. $("#gpo").removeClass("is-invalid");
  607. invalidDatalist("#materia", false);
  608. $("#fecha_inicial").removeClass("is-invalid");
  609. $("#fecha_falta").removeClass("is-invalid");
  610. $("#fecha_cambio").removeClass("is-invalid");
  611. if($("#tipo").val() == 1){//reposición
  612. if($("#fecha_falta").val() == ""){
  613. $("#fecha_falta").addClass("is-invalid");
  614. error = true;
  615. }
  616. if($("#fecha_inicial").val() == ""){//fecha reposición
  617. $("#fecha_inicial").addClass("is-invalid");
  618. error = true;
  619. }
  620. }else{
  621. if($("#fecha_cambio").val() == ""){
  622. $("#fecha_cambio").addClass("is-invalid");
  623. error = true;
  624. }
  625. }
  626. if($("#horario").val().trim() == "" || $("#horario").val() === null){
  627. invalidDatalist("#horario", true);
  628. error = true;
  629. }
  630. if(myBtn.data("tipo") == 2 ){
  631. $('#formaModal').prop("action", "./action/reposicion_update.php");
  632. }else{
  633. $('#formaModal').prop("action", "./action/reposicion_insert.php");
  634. }
  635. return !error;
  636. }
  637. function cambiaTipo(tipo){
  638. if (tipo == 1){//reposición
  639. $(".repo_block").show();
  640. $(".cambio_block").hide();
  641. $(".repo_block").find("input[type=text]").attr("required", true);
  642. $(".cambio_block").find("input[type=text]").removeAttr("required");
  643. $("#hora_nombre").text("Hora reposición *");
  644. }else{//Cambio de salón
  645. $(".repo_block").hide();
  646. $(".cambio_block").show();
  647. $(".repo_block").find("input[type=text]").removeAttr("required");
  648. $(".cambio_block").find("input[type=text]").attr("required", true);
  649. $("#hora_nombre").text("Hora cambio *");
  650. var hora = $("#dlMateria ul li.selected").data("hr");
  651. var min = $("#dlMateria ul li.selected").data("min");
  652. $("#hora_ini").val(hora)
  653. $("#min_ini").val(min)
  654. }
  655. }
  656. $(document).ready(function(){
  657. //fecha de clase
  658. $(".date-picker" ).datepicker(datepickerOptions);
  659. $(".date-picker" ).datepicker( $.datepicker.regional[ "es" ] );
  660. //fecha de clase
  661. $(".date-picker-filtro" ).datepicker(datepickerOptions_filtro);
  662. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  663. //fecha nueva
  664. $(".date-picker-future" ).datepicker(datepickerOptions_future);
  665. $(".date-picker-future" ).datepicker( $.datepicker.regional[ "es" ] );
  666. <?php if(/*$_SESSION["jefe_carrera"] ||*/ $user->admin){ ?>
  667. function creaOpcion(id_lista, nombre, gpo, dia, hora){
  668. return '<li data-id="'+id_lista+'" >'+nombre+' ('+gpo+') - '+dia+' '+hora.substr(0, 5)+'</li>';
  669. }
  670. $('#filtro_final').focus(function(){
  671. $("#filtro_final").removeClass("is-invalid");
  672. });
  673. $("#dlProfesor ul li").click(function(){//cambia datalist
  674. var pid = $(this).data('id');
  675. //busca materias del profesor
  676. $.ajax({
  677. url: './action/materiasdiaprofesor_select.php',
  678. type: 'POST',
  679. dataType: 'json',
  680. data: { id: pid, },
  681. success: function(result) {
  682. if(result["error"]!= "" && result["error"] !== undefined){
  683. triggerMessage(result["error"], "Error");
  684. $("#modal").modal('hide');
  685. }else{
  686. $("#dlMateria ul").html("");
  687. for(i=0; i<result["materias"].length; i++){
  688. var html = creaOpcion(result["materias"][i]["Horario_id"],
  689. result["materias"][i]["Materia_desc"],
  690. result["materias"][i]["Grupo_desc"]+" "+result["materias"][i]["Carrera_prefijo"],
  691. result["materias"][i]["Dia_desc"],
  692. result["materias"][i]["Hora_inicio"]
  693. );
  694. $("#dlMateria ul").append(html);
  695. }
  696. setDatalistFirst("#horario");
  697. }
  698. },
  699. error: function(jqXHR, textStatus, errorThrown ){
  700. triggerMessage(errorThrown, "Error");
  701. }
  702. });//ajax
  703. });
  704. <?php } ?>
  705. //Actualiza días elegibles de calendario
  706. $("#dlMateria ul li").click(function(){//cambia datalist
  707. _dia_valido = $(this).data('dia');
  708. $.ajax({
  709. url: './action/asistenciasprofesor_select.php',
  710. type: 'POST',
  711. dataType: 'json',
  712. data: { "id": $("#prof").val(), "hor": $(this).data("id") },
  713. success: function(result) {
  714. if(result["error"]!= "" && result["error"] !== undefined){
  715. triggerMessage(result["error"], "Error");
  716. $('#modal').modal("hide");
  717. }else{
  718. _dias_asistencia = result["asistenciaArr"];
  719. }
  720. },
  721. error: function(jqXHR, textStatus, errorThrown ){
  722. triggerMessage(errorThrown, "Error");
  723. }
  724. });//ajax
  725. $(".date-picker" ).datepicker(datepickerOptions);
  726. var hora = $(this).data("hr");
  727. var min = $(this).data("min");
  728. $("#hora_ini").val(hora)
  729. $("#min_ini").val(min)
  730. });
  731. $("#dlTipo ul li").click(function(){//cambia datalist
  732. cambiaTipo($(this).data('id'));
  733. $(".date-picker" ).datepicker(datepickerOptions);
  734. });
  735. $('#modal_confirm').on('show.bs.modal', function (event) {
  736. var button = $(event.relatedTarget); // Button that triggered the modal
  737. var id = button.parents("tr").data("id");
  738. $("#id_borrar").val(id);
  739. });
  740. $(".btn-borrar").click(function(){
  741. var r_id = $("#id_borrar").val();
  742. $.ajax({
  743. url: './action/reposicion_delete.php',
  744. type: 'POST',
  745. dataType: 'json',
  746. data: { id: r_id},
  747. success: function(result) {
  748. if(result["error"]!= "" && result["error"] !== undefined){
  749. triggerMessage(result["error"], "Error");
  750. }else{
  751. triggerMessage(result["ok"], "Éxito");
  752. $("#id"+r_id).remove();
  753. }
  754. },
  755. error: function(jqXHR, textStatus, errorThrown ){
  756. triggerMessage(errorThrown, "Error");
  757. }
  758. });//ajax
  759. $('#modal_confirm').modal("hide");
  760. });
  761. $('#modal').on('show.bs.modal', function (event) {
  762. var button = $(event.relatedTarget); // Button that triggered the modal
  763. var tipo = button.data('tipo'); // 1 alta, 2 edicion
  764. var modal = $(this);
  765. $("#modal .is-invalid").removeClass("is-invalid");
  766. //$(this).find(".form-control:first-child").focus();
  767. $("#errorBox").collapse('hide');
  768. $("#errorBox_text").html("");
  769. if(tipo == 1){//alta
  770. $("#submitBtn").data('tipo', 1);
  771. $("#modalLabel").html("Crear Reposición");
  772. modal.find("input[type=text]").val("");
  773. modal.find("#alumnos").val("15");
  774. $("#plan").attr("readonly", false);
  775. $("#sem").attr("readonly", false);
  776. $("#gpo").attr("readonly", false);
  777. //$("#prof").attr("readonly", false);
  778. disableDatalist("#horario", false);
  779. disableDatalist("#tipo", false);
  780. if($("#prof").length>0)
  781. disableDatalist("#prof", false);
  782. setDatalistFirst("#tipo");
  783. setDatalistFirst("#aula");
  784. setDatalistFirst("#horario");
  785. $("#dlMateria ul li:first").click();
  786. }else{//editar
  787. $("#submitBtn").data('tipo', 2);
  788. $("#modalLabel").html("Editar Reposición");
  789. $("#plan").attr("readonly", true);
  790. $("#sem").attr("readonly", true);
  791. $("#gpo").attr("readonly", true);
  792. //$("#materia").attr("readonly", true);
  793. disableDatalist("#horario");
  794. disableDatalist("#tipo");
  795. /*if($("#prof").length>0)
  796. disableDatalist("#prof");
  797. $("#prof").attr("readonly", true);*/
  798. var r_id = $(button).parents("tr").data("id");
  799. $("#id").val(r_id);
  800. $.ajax({
  801. url: './action/reposicion_select.php',
  802. type: 'POST',
  803. dataType: 'json',
  804. data: { id: r_id },
  805. success: function(result) {
  806. if(result["error"]!= "" && result["error"] !== undefined){
  807. triggerMessage(result["error"], "Error");
  808. $("#modal").modal('hide');
  809. }else{
  810. //setDatalist("#prof", result["profesor"]);
  811. $('#salon').val(result["salon"]);
  812. $("#fecha_falta").val(result["fecha_clase"]);
  813. $('#hora_ini').val(result["hora_ini"]);
  814. $('#min_ini').val(result["min_ini"]);
  815. $('#comentario').val(result["comentario"]);
  816. $('#alumnos').val(result["alumnos"]);
  817. setDatalist("#horario", result["horario"]);
  818. setDatalist("#profesor", result["profesor"]);
  819. if(result["tipo"]){
  820. setDatalist("#tipo", 1);
  821. cambiaTipo(1);
  822. $("#fecha_inicial").val(result["fecha_nueva"]);
  823. }else{
  824. setDatalist("#tipo", 2);
  825. cambiaTipo(2);
  826. $("#fecha_cambio").val(result["fecha_nueva"]);
  827. }
  828. _dia_valido = parseInt(result["dia"]);
  829. $(".date-picker" ).datepicker(datepickerOptions);
  830. $("#dlTipo ul li:selected").click();
  831. setDatalist("#aula", result["aula"]);
  832. modal.modal('show');
  833. }
  834. },
  835. error: function(jqXHR, textStatus, errorThrown ){
  836. triggerMessage(errorThrown, "Error");
  837. $("#modal").modal('hide');
  838. //$('#messageBox')[0].scrollIntoView({ block: "end" });
  839. }
  840. });//ajax
  841. }
  842. });//show
  843. });
  844. $(function() {
  845. $('[data-toggle="tooltip"]').tooltip()
  846. })
  847. </script>
  848. <script src="js/messages.js"></script>
  849. <script type="module" src="js/reposiciones.js"></script>
  850. </body>
  851. </html>