asignacion_crear.php 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826
  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. /*print_r($user);
  10. print_r($user->user["id"]);
  11. echo "****|";
  12. print_r($user->acceso);//null sin permisos, w o r
  13. echo "|****|";
  14. print_r($user->profesor);
  15. echo "|****|";
  16. print_r($user->facultad["facultad_id"]);
  17. exit();*/
  18. //profesor, admin, rol, facultad
  19. if ($user->acceso === null && !$user->admin){
  20. die(header('Location: index.php'));
  21. exit();
  22. }
  23. //if (!$user->admin && in_array($user->acceso, ['n']))
  24. //die(header('Location: main.php?error=1'));
  25. //$user->print_to_log('Reposiciones');
  26. //$write = $user->admin || in_array($user->acceso, ['w']);
  27. $write = true; //
  28. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo_id])['esta_en_periodo'];
  29. //if($user->jefe_carrera){
  30. //$prof_rs = $db->query('SELECT DISTINCT * FROM fs_profesores(null, null, :fac) ORDER BY PROFESOR_NOMBRE', [':fac' => $user->facultad["facultad_id"]]);
  31. $prof_rs = $db->query('SELECT DISTINCT PROFESOR.* FROM PROFESOR
  32. JOIN HORARIO_VIEW USING (PROFESOR_ID_ID)
  33. WHERE FACULTAD_ID = :fac', [':fac' => $user->facultad["facultad_id"]]);
  34. //}
  35. //Duraciones
  36. $duracion_rs = $db->query("select * from duracion order by duracion_interval");
  37. if(!is_null($user->periodo_id)){
  38. //Periodo
  39. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo_id]);
  40. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  41. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  42. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  43. else{
  44. $dias = 3;
  45. if( intval(date("w")) >=3 && intval(date("w"))<=5 )//Mie a Vie
  46. $dias+=3;
  47. else if( intval(date("w")) ==6 )//Sab
  48. $dias+=2;
  49. else if( intval(date("w")) ==0 )//Do
  50. $dias+=1;
  51. $fecha_man = date("d/m/Y", strtotime("+".$dias." day"));
  52. }
  53. /*
  54. // Materias
  55. $id_prof = $user->profesor;
  56. //$facultad_id = 28;
  57. $materias_rs = $db->query('SELECT * FROM fs_materiasprofesor(:id)', [':id' => $id_prof]);
  58. */
  59. if(isset($_POST["fecha_inicial"]))
  60. $fecha_ini = $_POST["fecha_inicial"];
  61. else
  62. $fecha_ini = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  63. if(isset($_POST["fecha_final"]))
  64. $fecha_fin = $_POST["fecha_final"];
  65. else
  66. $fecha_fin = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"]));
  67. $date = DateTime::createFromFormat('d/m/Y', $fecha_ini);
  68. $fecha_ini_db = $date->format('Y-m-d');
  69. $date = DateTime::createFromFormat('d/m/Y', $fecha_fin);
  70. $fecha_fin_db = $date->format('Y-m-d');
  71. }
  72. ?>
  73. <!DOCTYPE html>
  74. <html lang="en">
  75. <head>
  76. <meta charset="UTF-8">
  77. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  78. <title>Reposiciones crear |
  79. <?= $user->facultad['facultad'] ?? "Administrador"; ?>
  80. </title>
  81. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"
  82. integrity="sha512-iecdLmaskl7CVkqkXNQ/ZH/XLlvWZOJyj7Yy7tcenmpD1ypASozpmT/E0iPtmFIB46ZmdtAc9eNBvH0H/ZpiBw=="
  83. crossorigin="anonymous" referrerpolicy="no-referrer" />
  84. <?php
  85. include 'import/html_css_files.php';
  86. ?>
  87. <link rel="stylesheet" href="css/jquery-ui.css">
  88. <link rel="stylesheet" href="css/calendar.css">
  89. <style>
  90. .wizard { height: 20px; width: 80%; background: #D0D0D0; }
  91. .wizard.full { background: #D0D0D0; }
  92. .wizard.active > div:first-child { background: #00A6CE; }
  93. .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); }
  94. </style>
  95. <script src="js/jquery.min.js"></script>
  96. <script src="js/bootstrap/popper.min.js"></script>
  97. <script src="js/bootstrap/bootstrap.min.js"></script>
  98. <script src="js/jquery-ui.js"></script>
  99. <script src="js/datepicker-es.js"></script>
  100. </head>
  101. <!-- -->
  102. <body style="display: block;">
  103. <?php
  104. include('include/constantes.php');
  105. include("import/html_header.php");
  106. html_header("Solicitud de salones", "Sistema de gestión de checador");
  107. ?>
  108. <main class="container content marco content-margin" id="local-app">
  109. <?php
  110. if($write==true) {?>
  111. <!-- Botón para abrir el modal -->
  112. <div class="row mb-4">
  113. <div class="col-12 text-right">
  114. <button type="button" class="btn btn-outline-secondary" data-tipo="1" data-toggle="modal" data-target="#modal" <?php if (!$en_fecha ) { echo "disabled"; } ?>><span class="ing-mas ing-fw"></span>Crear reposición</button>
  115. </div>
  116. </div>
  117. <?php }?>
  118. <section id="message"></section>
  119. <?php require('import/periodo.php') ?>
  120. <?php if(!is_null($user->periodo_id)) { ?>
  121. <form id="asistencia" method="post" onsubmit="return validaFechas()">
  122. <div class="form-box">
  123. <input type="hidden" name="facultad" value="">
  124. <div class="form-group row">
  125. <label for="filtro_inicial" class="col-4 col-form-label">Fecha inicial</label>
  126. <div class="col-8 col-sm-4">
  127. <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;?>">
  128. <div class="invalid-feedback">No es una fecha válida.</div>
  129. </div>
  130. </div>
  131. <div class="form-group row">
  132. <label for="filtro_final" class="col-4 col-form-label">Fecha final</label>
  133. <div class="col-8 col-sm-4">
  134. <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;?>">
  135. <div class="invalid-feedback">El rango de fechas no es válido.</div>
  136. </div>
  137. </div>
  138. </div>
  139. <div class="form-group row justify-content-center">
  140. <button type="submit" class="btn btn-outline-primary mr-2" id="btn-buscar"><span class="ing-buscar ing-fw"></span> Buscar</button>
  141. <button type="button" class="btn btn-outline-danger" onclick="window.location.href = window.location.href"><span class="ing-borrar ing-fw"></span> Limpiar</button>
  142. </div>
  143. </form>
  144. <?php
  145. $reposiciones_rs = $db->query('SELECT * FROM fs_reposiciones_solicitud(:f_ini, :f_fin, :usr ,NULL, NULL)', [':f_ini' => $fecha_ini_db, ':f_fin' => $fecha_fin_db, ':usr' => $user->user["id"]]);
  146. }
  147. ?>
  148. <div class="row">
  149. <?php
  150. if(isset($reposiciones_rs) && count($reposiciones_rs)>0){ ?>
  151. <h3 class="mb-3">Reposiciones creadas</h3>
  152. <div class="col-12 table-responsive px-0">
  153. <table class="table table-sm table-striped table-white">
  154. <thead class="thead-dark">
  155. <tr >
  156. <th>Estado</th>
  157. <th>Responsable</th>
  158. <th style="width:160px">Fecha falta</th>
  159. <th style="width:160px">Fecha reposición</th>
  160. <th style="width:160px">Duración</th>
  161. <th>Salón</th>
  162. <?php if($write){ ?><th>Acciones</th><?php } ?>
  163. </tr>
  164. </thead>
  165. <tbody>
  166. <?php
  167. foreach($reposiciones_rs as $reposicion){
  168. ?>
  169. <tr data-id="<?php echo $reposicion["reposicion_id"]; ?>" id="id<?php echo $reposicion["reposicion_id"]; ?>">
  170. <td class="align-middle text-center" style="color:<?php echo $reposicion["estado_color"];?>" title="<?php echo $reposicion["estado_nombre"];?>">
  171. <?php if($reposicion["estado_reposicion_id"]<3){ ?>
  172. <div class="wizard <?php if(intval($reposicion["estado_reposicion_id"])==2) echo "active";?> d-flex mx-auto">
  173. <div class="w-50 h-100"></div>
  174. <div class=""></div>
  175. </div>
  176. <?php } else if($reposicion["estado_reposicion_id"]==3){?>
  177. <div class="text-success text-center pt-1">
  178. <span class="ing-autorizar ing-lg"></span>
  179. </div>
  180. <?php } else {?>
  181. <div class="text-danger text-center pt-1">
  182. <span class="ing-negar ing-lg"></span>
  183. </div>
  184. <?php } ?>
  185. </td>
  186. <td class="align-middle"><?php echo $reposicion["materia_nombre"]; ?></td>
  187. <td class="align-middle text-center"><?php
  188. echo date("d/m/Y", strtotime($reposicion["fecha_clase"]))."<br>".substr($reposicion["horario_hora"],0,-3)." a ".substr($reposicion["horario_hora_fin"],0,-3)." hrs.";;
  189. ?>
  190. </td>
  191. <td class="align-middle text-center"><?php
  192. 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.";
  193. ?>
  194. </td>
  195. <td class="align-middle text-center"><?php
  196. echo $reposicion["duracion_total"];
  197. ?>
  198. </td>
  199. <td class="align-middle text-center"><?php
  200. if($reposicion["salon_id"] != ""){
  201. echo $reposicion["salon_id"];
  202. }else
  203. echo "Pendiente";
  204. ?>
  205. </td>
  206. <?php if($write){ ?>
  207. <td class="align-middle text-center icono-acciones">
  208. <?php
  209. //no se ha aprobado
  210. if($reposicion["estado_reposicion_id"] == 1){?>
  211. <a href="#" data-tipo="2" title="Editar" data-toggle="modal" data-target="#modal"><?php echo $ICO["editar"];?></a>
  212. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Borrar"><?php echo $ICO["cancelar"];?></a>
  213. <?php } ?>
  214. </td>
  215. <?php } ?>
  216. </tr>
  217. <?php }
  218. ?>
  219. </tbody>
  220. </table>
  221. </div>
  222. <?php } else {
  223. if(is_null($user->periodo_id)){ ?>
  224. <div class="col-12 text-center">
  225. <h4 class="mt-4 text-danger">Selecciona un periodo</h4>
  226. </div>
  227. <?php } else {?>
  228. <div class="col-12 text-center">
  229. <h4 class="mt-4 text-danger">No tienes solicitudes disponibles que cumplan con los filtros</h4>
  230. </div>
  231. <?php }
  232. } ?>
  233. </div>
  234. <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  235. <div class="modal-dialog modal-dialog-centered modal-xl" role="document">
  236. <div class="modal-content">
  237. <div class="modal-header">
  238. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Crear Reposición</span>
  239. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  240. <span aria-hidden="true">&times;</span>
  241. </button></h4>
  242. </div>
  243. <div class="modal-body">
  244. <form action="./action/asignacion_insert.php" method="post" id="formaModal" onsubmit="return submitForm()">
  245. <input type="hidden" name="id" id="id">
  246. <input type="hidden" name="estado" value="1">
  247. <div class="form-box">
  248. <div class="form-group row" id="profBlock">
  249. <label for="prof" class="col-4 col-form-label">Profesor responsable*</label>
  250. <div class="col-8">
  251. <div class="datalist datalist-select mb-1 w-100" id="dlProfesor">
  252. <div class="datalist-input">Selecciona un profesor</div>
  253. <span class="ing-buscar icono"></span>
  254. <ul style="display:none">
  255. <?php foreach($prof_rs as $prof){?>
  256. <li data-id="<?php echo $prof["profesor_id"];?>" <?php if($prof["profesor_id"]==$user->profesor){ echo "class='selected'";} ?> ><?php echo $prof["profesor_nombre"];?></li>
  257. <?php } ?>
  258. </ul>
  259. <input type="hidden" id="prof" name="prof" value="">
  260. </div>
  261. </div>
  262. </div>
  263. </div>
  264. <div class="form-box prof-selected">
  265. <div class="form-group row">
  266. <label for="tipo" class="col-4 col-form-label">Tipo *</label>
  267. <div class="col-8">
  268. <div class="datalist datalist-select mb-1 w-100" id="dlTipo">
  269. <div class="datalist-input">Reposición</div>
  270. <span class="ing-buscar icono"></span>
  271. <ul style="display:none">
  272. <li data-id="1">Reposición</li>
  273. <li data-id="2">Cambio de salón</li>
  274. </ul>
  275. <input type="hidden" id="tipo" name="tipo" value="1">
  276. </div>
  277. </div>
  278. </div>
  279. <div class="form-group row materia-block">
  280. <label for="duracion" class="col-4 col-form-label">Duración</label>
  281. <div class="col-4">
  282. <select name="duracion" id="duracion" class="form-control" required="required">
  283. <?php foreach($duracion_rs as $dura){?>
  284. <option value="<?php echo $dura["duracion_id"];?>" data-duracion="<?php echo $dura["duracion_interval"];?>" ><?php echo $dura["duracion_nombre"];?></option>
  285. <?php } ?>
  286. </select>
  287. </div>
  288. </div>
  289. <div class="form-group row repo_block materia-block">
  290. <label for="fecha_inicial" class="col-4 col-form-label">Fecha de asignación *</label>
  291. <div class="col-8">
  292. <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="">
  293. <small class="form-text text-muted">Las solicitudes de asignación se deben solicitar con al menos 72hrs de anticipación.<br>
  294. Recuerda que en sábado el límite para terminar la clase es a las 15:00hrs.
  295. </small>
  296. </div>
  297. </div>
  298. <div class="form-group row materia-block">
  299. <label for="hora_ini" class="col-4 col-form-label" id="hora_nombre">Hora reposición *</label>
  300. <?php
  301. //define("HORA_FINAL", 22);
  302. //define("FRACCION_HORA", 15);
  303. $default_h = 7; $default_m = 15;
  304. ?>
  305. <div class="col-4">
  306. <select name="hora_ini" id="hora_ini" class="form-control" required="required">
  307. <?php for($h = $default_h; $h < HORA_FINAL; $h++){?>
  308. <option value="<?php echo sprintf( '%02d', $h );?>" <?php if($default_h == $h){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $h );?></option>
  309. <?php } ?>
  310. </select>
  311. </div>
  312. <div class="col-4">
  313. <select name="min_ini" id="min_ini" class="form-control" required="required">
  314. <?php for($m = 0; $m < 60; $m+=(60/FRACCION_HORA)){?>
  315. <option value="<?php echo sprintf( '%02d', $m );?>" <?php if($default_m == $m){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $m );?></option>
  316. <?php } ?>
  317. </select>
  318. </div>
  319. </div>
  320. <div class="form-group row materia-block">
  321. <label for="salon" class="col-4 col-form-label">Alumnos aproximados *</label>
  322. <div class="col-8 col-md-4">
  323. <input type="number" name="alumnos" id="alumnos" class="form-control" value="1" min="1" max="50">
  324. </div>
  325. </div>
  326. <div class="form-group row materia-block">
  327. <label for="aula" class="col-4 col-form-label">Tipo aula *</label>
  328. <div class="col-8">
  329. <div class="datalist datalist-select mb-1 w-100" id="dlAula">
  330. <div class="datalist-input">Salón</div>
  331. <span class="ing-buscar icono"></span>
  332. <ul style="display:none">
  333. <li data-id="1">Salón</li>
  334. <li data-id="2">Sala de cómputo</li>
  335. <li data-id="3">Salón/Taller de la facultad</li>
  336. </ul>
  337. <input type="hidden" id="aula" name="aula" value="1">
  338. </div>
  339. </div>
  340. </div>
  341. <div class="form-group row materia-block">
  342. <label for="comentario" class="col-4 col-form-label">Comentarios</label>
  343. <div class="col-8">
  344. <p><i>Requerimientos específicos del salón, software especializado, etc.</i></p>
  345. <textarea rows="3" class="form-control" id="comentario" name="comentario"></textarea>
  346. </div>
  347. </div>
  348. </div>
  349. <div class="form-group row mt-3">
  350. <div class="offset-4 col-8">
  351. <button type="submit" class="btn btn-outline-primary materia-block" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  352. <button type="reset" class="btn btn-outline-danger" data-dismiss="modal"><?php echo $ICO["cancelar"];?> Cancelar</button>
  353. </div>
  354. </div>
  355. </form>
  356. </div>
  357. </div>
  358. </div>
  359. </div>
  360. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  361. <div class="modal-dialog modal-dialog-centered" role="document">
  362. <div class="modal-content">
  363. <div class="modal-body">
  364. <div class="row">
  365. <div class="col">
  366. <p class="font-weight-bold">¿Estás seguro de que quieres borrar la reposición?</p>
  367. <p>Esta acción no se puede deshacer.</p>
  368. </div>
  369. </div>
  370. </div>
  371. <div class="modal-footer">
  372. <input type="hidden" id="id_borrar" value="">
  373. <button type="button" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Borrar</button>
  374. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  375. </div>
  376. </div>
  377. </div>
  378. </div>
  379. </main>
  380. <? include "import/html_footer.php"; ?>
  381. <?php
  382. //--Manejo de errores y mensajes de exito
  383. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  384. switch ($_GET["error"]){
  385. case 0: $errorDesc = "No se reciberon los datos de la solicitud de asignación."; break;
  386. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la solicitud de asignacióno."; break;
  387. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la solicitud de asignación."; break;
  388. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  389. case 4: $errorDesc = "Ocurrió un error al cargar los datos de la solicitud de asignación."; break;
  390. case 6: $errorDesc = "La solicitud de asignación que buscas no existe. Consulta la lista de reopsiciones disponibles en esta sección."; break;
  391. case 7: $errorDesc = "La solicitud de asignación se empalma con el horario del grupo y no se puede guardar."; break;
  392. case 8: $errorDesc = "El salón de la solicitud de asignación está siendo utilizado ese día a esa hora y no se puede guardar."; break;
  393. case 9: $errorDesc = "El profesor está asigndo a otra clase o solicitud de asignación el mismo día a la misma hora y no se puede guardar."; break;
  394. case 10: $errorDesc = "El profesor está asigndo a una materia el mismo día a la misma hora y no se puede guardar."; break;
  395. case 11: $errorDesc = "No hay clases asignadas para esa materia y grupo en la fecha de falta."; break;
  396. }
  397. }
  398. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  399. switch ($_GET["ok"]){
  400. case 0: $successDesc = "La solicitud de asignación se guardó correctamente."; break;
  401. case 1: $successDesc = "La solicitud de asignación se actualizó correctamente."; break;
  402. }
  403. }
  404. require_once 'js/messages.php';
  405. ?>
  406. <script>
  407. <?php if(isset($errorDesc)){ ?>
  408. triggerMessage("<?php echo $errorDesc;?>", "Error");
  409. <?php } else if(isset($successDesc)){ ?>
  410. triggerMessage("<?php echo $successDesc;?>", "Éxito", "success");
  411. <?php } ?>
  412. var vacaciones=[
  413. <?php
  414. $vacaciones_rs = $db->query('SELECT diasfestivos_dia from diasfestivos d where :periodo = any(d.periodos_id)', [':periodo' => $user->periodo_id ]);
  415. foreach($vacaciones_rs as $v){ echo '"'.$v["diasfestivos_dia"].'",';}
  416. ?>
  417. ];
  418. var _dias_asistencia = [];//ya registró asistencia, cambia con ajax
  419. var _dia_valido = 0;
  420. var _fecha_manhana = "<?php echo $fecha_man; ?>";
  421. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  422. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  423. var datepickerOptions_filtro = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final};
  424. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final,
  425. beforeShowDay: function(date) {
  426. var day = date.getDay();
  427. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  428. if (day === _dia_valido) {// 0 representa el domingo
  429. if (vacaciones.indexOf(dateString) !== -1 || _dias_asistencia.indexOf(dateString) !== -1)
  430. return [false];
  431. else
  432. return [true];
  433. }else{
  434. return [false];
  435. }
  436. }
  437. };
  438. var datepickerOptions_future = { dateFormat: "dd/mm/yy", minDate:_fecha_manhana, maxDate:_periodo_fecha_final,
  439. beforeShowDay: function(date) {
  440. var day = date.getDay();
  441. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  442. if (day === 0) {// 0 representa el domingo
  443. return [false];
  444. } else {
  445. if (vacaciones.indexOf(dateString) !== -1) {
  446. return [false];
  447. } else {
  448. return [true];
  449. }
  450. }
  451. }
  452. };
  453. function diaAAno(fecha_str){//de dd/mm/yyyy a yyyy-mm-dd
  454. if(fecha_str.charAt(2) == "/" && fecha_str.charAt(5) == "/"){//dd/mm/yyyy
  455. var fecha_arr = fecha_str.split("/");
  456. return fecha_arr[2]+"-"+fecha_arr[1]+"-"+fecha_arr[0];
  457. }
  458. return fecha_str;
  459. }
  460. function fechaMayor(fechaI, fechaF) {//cual es mayor >0 I mayor <0 F mayor
  461. return (Date.parse(diaAAno(fechaI)) - Date.parse(diaAAno(fechaF)));
  462. }
  463. function validaFechas(){
  464. if(fechaMayor($('#filtro_inicial').val().trim(), $('#filtro_final').val().trim()) > 0){
  465. $('#filtro_final').addClass("is-invalid");
  466. return false;
  467. }
  468. return true;
  469. }
  470. function submitForm(){
  471. var myBtn = $('#submitBtn');
  472. var error = false;
  473. $("#gpo").removeClass("is-invalid");
  474. $("#fecha_inicial").removeClass("is-invalid");
  475. $("#fecha_falta").removeClass("is-invalid");
  476. $("#fecha_cambio").removeClass("is-invalid");
  477. if($("#tipo").val() == 1){//reposición
  478. if($("#fecha_falta").val() == ""){
  479. $("#fecha_falta").addClass("is-invalid");
  480. error = true;
  481. }
  482. if($("#fecha_inicial").val() == ""){//fecha reposición
  483. $("#fecha_inicial").addClass("is-invalid");
  484. error = true;
  485. }
  486. }else{
  487. if($("#fecha_cambio").val() == ""){
  488. $("#fecha_cambio").addClass("is-invalid");
  489. error = true;
  490. }
  491. }
  492. if($("#horario").val().trim() == "" || $("#horario").val() === null){
  493. invalidDatalist("#horario", true);
  494. error = true;
  495. }
  496. if(myBtn.data("tipo") == 2 ){
  497. $('#formaModal').prop("action", "./action/asignacion_update.php");
  498. }else{
  499. $('#formaModal').prop("action", "./action/asignacion_insert.php");
  500. }
  501. return !error;
  502. }
  503. function cambiaTipo(tipo){
  504. if (tipo == 1){//reposición
  505. $(".repo_block").show();
  506. $(".cambio_block").hide();
  507. $(".repo_block").find("input[type=text]").attr("required", true);
  508. $(".cambio_block").find("input[type=text]").removeAttr("required");
  509. $("#hora_nombre").text("Hora reposición *");
  510. }else{//Cambio de salón
  511. $(".repo_block").hide();
  512. $(".cambio_block").show();
  513. $(".repo_block").find("input[type=text]").removeAttr("required");
  514. $(".cambio_block").find("input[type=text]").attr("required", true);
  515. $("#hora_nombre").text("Hora cambio *");
  516. var hora = $("#dlMateria ul li.selected").data("hr");
  517. var min = $("#dlMateria ul li.selected").data("min");
  518. $("#hora_ini").val(hora)
  519. $("#min_ini").val(min)
  520. }
  521. }
  522. $(document).ready(function(){
  523. $(".prof-selected").hide();
  524. //fecha de clase
  525. $(".date-picker" ).datepicker(datepickerOptions);
  526. $(".date-picker" ).datepicker( $.datepicker.regional[ "es" ] );
  527. //fecha de clase
  528. $(".date-picker-filtro" ).datepicker(datepickerOptions_filtro);
  529. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  530. //fecha nueva
  531. $(".date-picker-future" ).datepicker(datepickerOptions_future);
  532. $(".date-picker-future" ).datepicker( $.datepicker.regional[ "es" ] );
  533. function creaOpcion(id_horario, dia, hora, min, nombre, gpo, duracion){
  534. return '<li data-id="'+id_horario+'" data-dia="'+dia+'" data-hr="'+hora+'" data-min="'+min+'" data-gpo="'+gpo+'" data-duracion="'+duracion+'">'+nombre+'</li>';
  535. }
  536. $('#filtro_final').focus(function(){
  537. $("#filtro_final").removeClass("is-invalid");
  538. });
  539. function obtieneProf(pid){
  540. return $.ajax({
  541. url: './action/reposicion_profesor_materias.php',
  542. type: 'POST',
  543. dataType: 'json',
  544. data: { id: pid, },
  545. //async: false,
  546. success: function(result) {
  547. if(result["error"]!= "" && result["error"] !== undefined){
  548. triggerMessage(result["error"], "Error");
  549. $("#modal").modal('hide');
  550. $(".prof-selected").hide();
  551. }else{
  552. $(".prof-selected").show();
  553. $("#dlMateria ul").html("");
  554. for(i=0; i<result["materias"].length; i++){
  555. var html = creaOpcion(result["materias"][i]["horario_id"],
  556. result["materias"][i]["horario_dia"],
  557. result["materias"][i]["horario_hora"],
  558. result["materias"][i]["horario_min"],
  559. result["materias"][i]["materia_nombre"],
  560. result["materias"][i]["grupo"],
  561. result["materias"][i]["duracion"]
  562. );
  563. $("#dlMateria ul").append(html);
  564. }
  565. }
  566. },
  567. error: function(jqXHR, textStatus, errorThrown ){
  568. triggerMessage(errorThrown, "Error");
  569. }
  570. });//ajax
  571. }
  572. $(document).on( "click", "#dlProfesor ul li", function(event){//cambia datalist
  573. var pid = $(this).data('id');
  574. //busca materias del profesor
  575. var profCarga = obtieneProf(pid);
  576. profCarga.done(function(){
  577. $("#dlMateria ul li:first").click();
  578. });
  579. });
  580. //Actualiza días elegibles de calendario
  581. $(document).on( "click", "#dlMateria ul li", function(event){//manda al frente de todos
  582. _dia_valido = $(this).data('dia');//variable global
  583. var grupo = $(this).data("gpo");
  584. var duracionMateria = $(this).data("duracion");
  585. $(".date-picker" ).datepicker(datepickerOptions);
  586. var hora = $(this).data("hr");
  587. var min = $(this).data("min");
  588. $("#hora_ini").val(hora)
  589. $("#min_ini").val(min)
  590. return $.ajax({
  591. url: './action/asistenciasprofesor_select.php',
  592. type: 'POST',
  593. dataType: 'json',
  594. data: { "id": $("#prof").val(), "hor": $(this).data("id") },
  595. //async: false,
  596. success: function(result) {
  597. if(result["error"]!= "" && result["error"] !== undefined){
  598. triggerMessage(result["error"], "Error");
  599. $('#modal').modal("hide");
  600. }else{
  601. _dias_asistencia = result["asistenciaArr"];
  602. $('#duracion option').each(function() {
  603. if ($(this).data("duracion") === duracionMateria) {
  604. // Selecciona la opción correspondiente en el select de "duracion"
  605. $(this).prop('selected', true);
  606. }
  607. });
  608. }
  609. },
  610. error: function(jqXHR, textStatus, errorThrown ){
  611. triggerMessage(errorThrown, "Error");
  612. }
  613. });//ajax
  614. });
  615. $("#dlTipo ul li").click(function(){//cambia datalist
  616. cambiaTipo($(this).data('id'));
  617. $(".date-picker" ).datepicker(datepickerOptions);
  618. });
  619. $('#modal_confirm').on('show.bs.modal', function (event) {
  620. var button = $(event.relatedTarget); // Button that triggered the modal
  621. var id = button.parents("tr").data("id");
  622. $("#id_borrar").val(id);
  623. });
  624. $(".btn-borrar").click(function(){
  625. var r_id = $("#id_borrar").val();
  626. $.ajax({
  627. url: './action/asignacion_delete.php',
  628. type: 'POST',
  629. dataType: 'json',
  630. data: { id: r_id},
  631. success: function(result) {
  632. if(result["error"]!= "" && result["error"] !== undefined){
  633. triggerMessage(result["error"], "Error");
  634. }else{
  635. triggerMessage(result["ok"], "Éxito", "success");
  636. $("#id"+r_id).remove();
  637. }
  638. },
  639. error: function(jqXHR, textStatus, errorThrown ){
  640. triggerMessage(errorThrown, "Error");
  641. }
  642. });//ajax
  643. $('#modal_confirm').modal("hide");
  644. });
  645. $('#modal').on('show.bs.modal', function (event) {
  646. var button = $(event.relatedTarget); // Button that triggered the modal
  647. var tipo = button.data('tipo'); // 1 alta, 2 edicion
  648. var modal = $(this);
  649. $("#modal .is-invalid").removeClass("is-invalid");
  650. //$(this).find(".form-control:first-child").focus();
  651. $("#errorBox").collapse('hide');
  652. $("#errorBox_text").html("");
  653. if(tipo == 1){//alta
  654. $("#submitBtn").data('tipo', 1);
  655. $("#modalLabel").html("Crear Reposición");
  656. modal.find("input[type=text]").val("");
  657. modal.find("#alumnos").val("15");
  658. $("#plan").attr("readonly", false);
  659. $("#sem").attr("readonly", false);
  660. $("#gpo").attr("readonly", false);
  661. //$("#prof").attr("readonly", false);
  662. disableDatalist("#horario", false);
  663. disableDatalist("#tipo", false);
  664. if($("#prof").length>0)
  665. disableDatalist("#prof", false);
  666. setDatalistFirst("#tipo");
  667. setDatalistFirst("#aula");
  668. setDatalistFirst("#horario");
  669. $("#dlMateria ul li:first").click();
  670. }else{//editar
  671. $("#submitBtn").data('tipo', 2);
  672. $("#modalLabel").html("Editar Reposición");
  673. $("#plan").attr("readonly", true);
  674. $("#sem").attr("readonly", true);
  675. $("#gpo").attr("readonly", true);
  676. //$("#materia").attr("readonly", true);
  677. disableDatalist("#horario");
  678. disableDatalist("#tipo");
  679. disableDatalist("#prof");
  680. /*if($("#prof").length>0)
  681. disableDatalist("#prof");
  682. $("#prof").attr("readonly", true);*/
  683. var r_id = $(button).parents("tr").data("id");
  684. $("#id").val(r_id);
  685. $.ajax({
  686. url: './action/asignacion_select.php',
  687. type: 'POST',
  688. dataType: 'json',
  689. data: { id: r_id },
  690. async: true,
  691. success: function(result) {
  692. if(result["error"]!= "" && result["error"] !== undefined){
  693. triggerMessage(result["error"], "Error");
  694. $("#modal").modal('hide');
  695. }else{
  696. //setDatalist("#prof", result["profesor"]);
  697. setDatalist("#prof", result["profesor"]);
  698. var profCarga = obtieneProf(result["profesor"]);
  699. //$('#salon').val(result["salon"]);
  700. $("#fecha_falta").val(result["fecha_clase"]);
  701. $('#hora_ini').val(result["hora_ini"]);
  702. $('#min_ini').val(result["min_ini"]);
  703. $('#comentario').val(result["comentario"]);
  704. $('#alumnos').val(result["alumnos"]);
  705. $("#fecha_inicial").val(result["fecha_nueva"]);
  706. $("#fecha_cambio").val(result["fecha_nueva"]);
  707. _dia_valido = parseInt(result["dia"]);
  708. $(".date-picker" ).datepicker(datepickerOptions);
  709. $("#dlTipo ul li:selected").click();
  710. profCarga.done(function(){
  711. setDatalist("#horario", result["horario"]);// No se actualiza TODO
  712. });
  713. setDatalist("#aula", result["aula"]);
  714. modal.modal('show');
  715. }
  716. },
  717. error: function(jqXHR, textStatus, errorThrown ){
  718. triggerMessage(errorThrown, "Error");
  719. $("#modal").modal('hide');
  720. //$('#messageBox')[0].scrollIntoView({ block: "end" });
  721. }
  722. });//ajax
  723. }
  724. });//show
  725. });
  726. $(function() {
  727. $('[data-toggle="tooltip"]').tooltip()
  728. })
  729. </script>
  730. <script src="js/messages.js"></script>
  731. <script type="module" src="js/reposiciones.js"></script>
  732. </body>
  733. </html>