asignacion_crear.php 39 KB

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