reposiciones_crear.php 54 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001
  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 PUESTO_USUARIO
  32. JOIN PUESTO_MATERIA USING (PUESTO_ID)
  33. JOIN HORARIO_VIEW USING (MATERIA_ID)
  34. JOIN HORARIO_PROFESOR USING (HORARIO_ID)
  35. JOIN PROFESOR USING (PROFESOR_ID)
  36. WHERE USUARIO_ID = :usr', [':usr' => $user->user["id"]]);
  37. //}
  38. //Duraciones
  39. $duracion_rs = $db->query("select * from duracion order by duracion_interval");
  40. if(!is_null($user->periodo_id)){
  41. //Periodo
  42. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo_id]);
  43. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  44. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  45. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  46. else{
  47. $dias = 3;
  48. if( intval(date("w")) >=3 && intval(date("w"))<=5 )//Mie a Vie
  49. $dias+=3;
  50. else if( intval(date("w")) ==6 )//Sab
  51. $dias+=2;
  52. else if( intval(date("w")) ==0 )//Do
  53. $dias+=1;
  54. $fecha_man = date("d/m/Y", strtotime("+".$dias." day"));
  55. }
  56. /*
  57. // Materias
  58. $id_prof = $user->profesor;
  59. //$facultad_id = 28;
  60. $materias_rs = $db->query('SELECT * FROM fs_materiasprofesor(:id)', [':id' => $id_prof]);
  61. */
  62. if(isset($_POST["fecha_inicial"]))
  63. $fecha_ini = $_POST["fecha_inicial"];
  64. else
  65. $fecha_ini = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  66. if(isset($_POST["fecha_final"]))
  67. $fecha_fin = $_POST["fecha_final"];
  68. else
  69. $fecha_fin = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"]));
  70. $date = DateTime::createFromFormat('d/m/Y', $fecha_ini);
  71. $fecha_ini_db = $date->format('Y-m-d');
  72. $date = DateTime::createFromFormat('d/m/Y', $fecha_fin);
  73. $fecha_fin_db = $date->format('Y-m-d');
  74. }
  75. ?>
  76. <!DOCTYPE html>
  77. <html lang="en">
  78. <head>
  79. <meta charset="UTF-8">
  80. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  81. <title>Reposiciones crear |
  82. <?= $user->facultad['facultad'] ?? "Administrador"; ?>
  83. </title>
  84. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"
  85. integrity="sha512-iecdLmaskl7CVkqkXNQ/ZH/XLlvWZOJyj7Yy7tcenmpD1ypASozpmT/E0iPtmFIB46ZmdtAc9eNBvH0H/ZpiBw=="
  86. crossorigin="anonymous" referrerpolicy="no-referrer" />
  87. <?php
  88. include 'import/html_css_files.php';
  89. ?>
  90. <link rel="stylesheet" href="css/jquery-ui.css">
  91. <link rel="stylesheet" href="css/calendar.css">
  92. <style>
  93. .wizard { height: 20px; width: 80%; background: #D0D0D0; }
  94. .wizard.full { background: #D0D0D0; }
  95. .wizard.active > div:first-child { background: #00A6CE; }
  96. .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); }
  97. </style>
  98. <script src="js/jquery.min.js"></script>
  99. <script src="js/bootstrap/popper.min.js"></script>
  100. <script src="js/bootstrap/bootstrap.min.js"></script>
  101. <script src="js/jquery-ui.js"></script>
  102. <script src="js/datepicker-es.js"></script>
  103. </head>
  104. <!-- -->
  105. <body style="display: block;">
  106. <?php
  107. include('include/constantes.php');
  108. include("import/html_header.php");
  109. html_header("Reposiciones de clase", "Sistema de gestión de checador");
  110. ?>
  111. <main class="container content marco content-margin" id="local-app">
  112. <?php if($write==true && isset($prof_rs) && count($prof_rs)>0) {?>
  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 reposición</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>Materia</th>
  160. <th>Tipo</th>
  161. <th style="width:160px">Fecha falta</th>
  162. <th style="width:160px">Fecha reposición</th>
  163. <th style="width:160px">Duración</th>
  164. <th>Salón</th>
  165. <?php if($write){ ?><th>Acciones</th><?php } ?>
  166. </tr>
  167. </thead>
  168. <tbody>
  169. <?php
  170. foreach($reposiciones_rs as $reposicion){
  171. ?>
  172. <tr data-id="<?php echo $reposicion["reposicion_id"]; ?>" id="id<?php echo $reposicion["reposicion_id"]; ?>">
  173. <td class="align-middle text-center" style="color:<?php echo $reposicion["estado_color"];?>" title="<?php echo $reposicion["estado_nombre"];?>">
  174. <?php if($reposicion["estado_reposicion_id"]<3){ ?>
  175. <div class="wizard <?php if(intval($reposicion["estado_reposicion_id"])==2) echo "active";?> d-flex mx-auto">
  176. <div class="w-50 h-100"></div>
  177. <div class=""></div>
  178. </div>
  179. <?php } else if($reposicion["estado_reposicion_id"]==3){?>
  180. <div class="text-success text-center pt-1">
  181. <span class="ing-autorizar ing-lg"></span>
  182. </div>
  183. <?php } else {?>
  184. <div class="text-danger text-center pt-1">
  185. <span class="ing-negar ing-lg"></span>
  186. </div>
  187. <?php } ?>
  188. </td>
  189. <td class="align-middle"><?php echo $reposicion["materia_nombre"]; ?></td>
  190. <td class="align-middle">
  191. <?php if($reposicion["es_reposicion"]) echo "Reposición"; else echo "Cambio"; ?>
  192. </td>
  193. <td class="align-middle text-center"><?php
  194. 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.";;
  195. ?>
  196. </td>
  197. <td class="align-middle text-center"><?php
  198. 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.";
  199. ?>
  200. </td>
  201. <td class="align-middle text-center"><?php
  202. echo $reposicion["duracion_total"];
  203. ?>
  204. </td>
  205. <td class="align-middle text-center"><?php
  206. if($reposicion["salon_id"] != ""){
  207. echo $reposicion["salon_id"];
  208. }else
  209. echo "Pendiente";
  210. ?>
  211. </td>
  212. <?php if($write){ ?>
  213. <td class="align-middle text-center icono-acciones">
  214. <?php
  215. //no se ha aprobado
  216. if($reposicion["estado_reposicion_id"] == 1){?>
  217. <a href="#" data-tipo="2" title="Editar" data-toggle="modal" data-target="#modal"><?php echo $ICO["editar"];?></a>
  218. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Borrar"><?php echo $ICO["cancelar"];?></a>
  219. <?php } ?>
  220. </td>
  221. <?php } ?>
  222. </tr>
  223. <?php }
  224. ?>
  225. </tbody>
  226. </table>
  227. </div>
  228. <?php } else {
  229. if(is_null($user->periodo_id)){ ?>
  230. <div class="col-12 text-center">
  231. <h4 class="mt-4 text-danger">Selecciona un periodo</h4>
  232. </div>
  233. <?php } else {?>
  234. <div class="col-12 text-center">
  235. <h4 class="mt-4 text-danger">No tienes reposiciones disponibles que cumplan con los filtros</h4>
  236. </div>
  237. <?php }
  238. } ?>
  239. </div>
  240. <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  241. <div class="modal-dialog modal-dialog-centered modal-xl" role="document">
  242. <div class="modal-content">
  243. <div class="modal-header">
  244. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Crear Reposición</span>
  245. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  246. <span aria-hidden="true">&times;</span>
  247. </button></h4>
  248. </div>
  249. <div class="modal-body">
  250. <form action="./action/reposicion_insert.php" method="post" id="formaModal" onsubmit="return submitForm()">
  251. <input type="hidden" name="id" id="id">
  252. <input type="hidden" name="estado" value="1">
  253. <input type="hidden" name="ciclo" id="ciclo" value="0">
  254. <input type="hidden" name="bloque" id="bloque" value="0">
  255. <div class="form-box">
  256. <div class="form-group row" id="profBlock">
  257. <label for="prof" class="col-4 col-form-label">Profesor *</label>
  258. <div class="col-8">
  259. <div class="datalist datalist-select mb-1 w-100" id="dlProfesor">
  260. <div class="datalist-input">Selecciona un profesor</div>
  261. <span class="ing-buscar icono"></span>
  262. <ul style="display:none">
  263. <?php foreach($prof_rs as $prof){?>
  264. <li data-id="<?php echo $prof["profesor_id"];?>" <?php if($prof["profesor_id"]==$user->profesor){ echo "class='selected'";} ?> ><?php echo $prof["profesor_nombre"];?></li>
  265. <?php } ?>
  266. </ul>
  267. <input type="hidden" id="prof" name="prof" value="">
  268. </div>
  269. </div>
  270. </div>
  271. </div>
  272. <div class="form-box prof-selected">
  273. <div class="form-group row" id="materiaBlock">
  274. <label for="horario" class="col-4 col-form-label">Materia *</label>
  275. <div class="col-8">
  276. <div class="datalist datalist-select mb-1 w-100" id="dlMateria">
  277. <div class="datalist-input">Selecciona una materia</div>
  278. <span class="ing-buscar icono"></span>
  279. <ul style="display:none">
  280. </ul>
  281. <input type="hidden" id="horario" name="horario" value="">
  282. </div>
  283. </div>
  284. </div>
  285. <div class="form-group row">
  286. <label for="tipo" class="col-4 col-form-label">Tipo *</label>
  287. <div class="col-8">
  288. <div class="datalist datalist-select mb-1 w-100" id="dlTipo">
  289. <div class="datalist-input">Reposición</div>
  290. <span class="ing-buscar icono"></span>
  291. <ul style="display:none">
  292. <li data-id="1">Reposición</li>
  293. <li data-id="2">Cambio de salón</li>
  294. </ul>
  295. <input type="hidden" id="tipo" name="tipo" value="1">
  296. </div>
  297. </div>
  298. </div>
  299. <div class="form-group row materia-block">
  300. <label for="duracion" class="col-4 col-form-label">Duración</label>
  301. <div class="col-4">
  302. <select name="duracion" id="duracion" class="form-control" required="required">
  303. <?php foreach($duracion_rs as $dura){?>
  304. <option value="<?php echo $dura["duracion_id"];?>" data-duracion="<?php echo $dura["duracion_interval"];?>" ><?php echo $dura["duracion_nombre"];?></option>
  305. <?php } ?>
  306. </select>
  307. </div>
  308. </div>
  309. <div class="form-group row cambio_block materia-block" style="display: none;">
  310. <label for="fecha_cambio" class="col-4 col-form-label">Fecha de cambio *</label>
  311. <div class="col-8">
  312. <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="">
  313. </div>
  314. </div>
  315. <div class="form-group row repo_block materia-block">
  316. <label for="fecha_falta" class="col-4 col-form-label">Fecha de falta *</label>
  317. <div class="col-8">
  318. <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="">
  319. </div>
  320. </div>
  321. <div class="form-group row repo_block materia-block">
  322. <label for="fecha_inicial" class="col-4 col-form-label">Fecha de reposicion *</label>
  323. <div class="col-8">
  324. <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="">
  325. <small class="form-text text-muted">Las reposiciones se deben solicitar con al menos 72hrs de anticipación.<br>
  326. Recuerda que en sábado el límite para terminar la clase es a las 15:00hrs.
  327. </small>
  328. </div>
  329. </div>
  330. <div class="form-group row materia-block">
  331. <label for="hora_ini" class="col-4 col-form-label" id="hora_nombre">Hora reposición *</label>
  332. <?php
  333. //define("HORA_FINAL", 22);
  334. //define("FRACCION_HORA", 15);
  335. $default_h = 7; $default_m = 15;
  336. ?>
  337. <div class="col-4">
  338. <select name="hora_ini" id="hora_ini" class="form-control" required="required">
  339. <?php for($h = $default_h; $h < HORA_FINAL; $h++){?>
  340. <option value="<?php echo sprintf( '%02d', $h );?>" <?php if($default_h == $h){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $h );?></option>
  341. <?php } ?>
  342. </select>
  343. </div>
  344. <div class="col-4">
  345. <select name="min_ini" id="min_ini" class="form-control" required="required">
  346. <?php for($m = 0; $m < 60; $m+=(60/FRACCION_HORA)){?>
  347. <option value="<?php echo sprintf( '%02d', $m );?>" <?php if($default_m == $m){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $m );?></option>
  348. <?php } ?>
  349. </select>
  350. </div>
  351. </div>
  352. <div class="form-group row materia-block">
  353. <label for="salon" class="col-4 col-form-label">Alumnos aproximados *</label>
  354. <div class="col-8 col-md-4">
  355. <input type="number" name="alumnos" id="alumnos" class="form-control" value="1" min="1" max="50">
  356. </div>
  357. </div>
  358. <div class="form-group row materia-block">
  359. <label for="aula" class="col-4 col-form-label">Tipo aula *</label>
  360. <div class="col-8">
  361. <div class="datalist datalist-select mb-1 w-100" id="dlAula">
  362. <div class="datalist-input">Salón</div>
  363. <span class="ing-buscar icono"></span>
  364. <ul style="display:none">
  365. <li data-id="1">Salón</li>
  366. <li data-id="2">Sala de cómputo</li>
  367. <li data-id="3">Salón/Taller de la facultad</li>
  368. </ul>
  369. <input type="hidden" id="aula" name="aula" value="1">
  370. </div>
  371. </div>
  372. </div>
  373. <div class="form-group row materia-block">
  374. <label for="comentario" class="col-4 col-form-label">Comentarios</label>
  375. <div class="col-8">
  376. <p><i>Requerimientos específicos del salón, software especializado, etc.</i></p>
  377. <textarea rows="3" class="form-control" id="comentario" name="comentario"></textarea>
  378. </div>
  379. </div>
  380. </div>
  381. <div class="form-group row mt-3">
  382. <div class="offset-4 col-8">
  383. <button type="submit" class="btn btn-outline-primary materia-block" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  384. <button type="reset" class="btn btn-outline-danger" data-dismiss="modal"><?php echo $ICO["cancelar"];?> Cancelar</button>
  385. </div>
  386. </div>
  387. </form>
  388. </div>
  389. </div>
  390. </div>
  391. </div>
  392. <!-- Modal del formulario -->
  393. <div class="modal fade" id="crearReposiciónOld" tabindex="-1" role="dialog" aria-labelledby="crearReposiciónLabel" aria-hidden="true">
  394. <div class="modal-dialog modal-xl" role="document">
  395. <div class="modal-content">
  396. <div class="modal-header">
  397. <h5 class="modal-title" id="crearReposiciónLabel">Crear Reposición</h5>
  398. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  399. <span aria-hidden="true">&times;</span>
  400. </button>
  401. </div>
  402. <div class="modal-body">
  403. <form id="form" class="form-horizontal">
  404. <div class="form-group step" id="step-1">
  405. <div class="form-box">
  406. <div class="form-group row">
  407. <label for="clave_profesor" class="col-4 col-form-label">Profesor</label>
  408. <div class="col-8">
  409. <input list="lista_profesores" name="clave_profesor" id="clave_profesor" class="form-control" placeholder="Profesor" required="required">
  410. <div class="valid-feedback">
  411. Profesor encontrado
  412. </div>
  413. <div class="invalid-feedback">
  414. Profesor no encontrado
  415. </div>
  416. <datalist id="lista_profesores">
  417. <?php
  418. foreach ($prof_rs as $prof) {
  419. ?>
  420. <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>
  421. <?php
  422. }
  423. ?>
  424. </datalist>
  425. <ul class="list-group" id="profesores"></ul>
  426. <input type="hidden" id="periodo_id" name="periodo_id" value="<?= $user->periodo_id ?>">
  427. <input type="hidden" id="profesor_id" name="profesor_id" value="">
  428. </div>
  429. </div>
  430. </div>
  431. </div>
  432. <div class="form-group step" id="step-2">
  433. <div class="form-box">
  434. <div class="form-group row">
  435. <label for="horario_reponer" class="col-4 col-form-label">Horario a reponer</label>
  436. <div class="col-8">
  437. <select name="horario_reponer" id="horario_reponer" class="form-control" required="required">
  438. </select>
  439. </div>
  440. </div>
  441. </div>
  442. <input type="hidden" name="horario_id" id="horario_id">
  443. </div>
  444. <div class="form-group step" id="step-3">
  445. <div class="form-box">
  446. <div class="form-group row">
  447. <label for="fechas_clase" class="col-4 col-form-label">Fecha de clase</label>
  448. <div class="col-8">
  449. <select name="fechas_clase" id="fechas_clase" class="form-control" required="required">
  450. </select>
  451. </div>
  452. </div>
  453. </div>
  454. </div>
  455. <div class="form-group step" id="step-4">
  456. <div class="form-box">
  457. <div class="form-group row">
  458. <label for="fecha_reponer" class="col-4 col-form-label">Fecha de reposición</label>
  459. <div class="col-6">
  460. <input type="text" placeholder="dd/mm/aaaa" name="fecha_reponer" id="fecha_reponer" class="form-control date-picker" required="required">
  461. </div>
  462. </div>
  463. <div class="form-group row">
  464. <label for="hora" class="col-4 col-form-label">Hora</label>
  465. <div class="col-3">
  466. <div id="hora" class="datalist datalist-select mb-1">
  467. <div class="datalist-input text-center">hh</div>
  468. <span class="ing-buscar icono"></span>
  469. <ul style="display:none">
  470. <?php foreach (range(7, 21) as $hora) { ?>
  471. <li data-id='<?= $hora ?>'><?= str_pad($hora, 2, "0", STR_PAD_LEFT) ?></li>
  472. <?php } ?>
  473. </ul>
  474. <input type="hidden" id="hora_reponer" name="horas" value="">
  475. </div>
  476. </div>
  477. <div class="col-3">
  478. <div id="minutos" class="datalist datalist-select mb-1">
  479. <div class="datalist-input text-center">mm</div>
  480. <span class="ing-buscar icono"></span>
  481. <ul style="display:none">
  482. <?php foreach (range(0, 45, 15) as $minuto) { ?>
  483. <li data-id='<?= $minuto ?>'><?= str_pad($minuto, 2, "0", STR_PAD_LEFT) ?></li>
  484. <?php } ?>
  485. </ul>
  486. <input type="hidden" id="minutos_reponer" name="minutos" value="">
  487. </div>
  488. </div>
  489. </div>
  490. </div>
  491. </div>
  492. <div class="form-group step" id="step-5">
  493. <div class="form-box">
  494. <div class="form-group row">
  495. <label for="descripcion_reposicion" class="col-4 col-form-label">Comentarios</label>
  496. <div class="col-6">
  497. <textarea name="descripcion_reposicion" id="descripcion_reposicion" rows="4" required="required" placeholder="Se requiere proyector, etc." maxlength="255" class="form-control"></textarea>
  498. </div>
  499. </div>
  500. <div class="form-group row align-items-center">
  501. <label class="col-4 col-form-label" for="sala">¿En sala de cómputo?</label>
  502. <div class="col-6">
  503. <div class="custom-control custom-switch">
  504. <input type="checkbox" class="custom-control-input" id="sala">
  505. <label class="custom-control-label" for="sala"></label>
  506. </div>
  507. </div>
  508. </div>
  509. </div>
  510. </div>
  511. </form>
  512. </div>
  513. <div class="modal-footer justify-content-center">
  514. <button class="btn btn-secondary" type="button" id="prev-button">Anterior</button>
  515. <button class="btn btn-secondary" type="button" id="next-button" disabled data-toggle="modal" data-target="#confirmationModal">Proponer reposición</button>
  516. </div>
  517. </div>
  518. </div>
  519. </div>
  520. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  521. <div class="modal-dialog modal-dialog-centered" role="document">
  522. <div class="modal-content">
  523. <div class="modal-body">
  524. <div class="row">
  525. <div class="col">
  526. <p class="font-weight-bold">¿Estás seguro de que quieres borrar la reposición?</p>
  527. <p>Esta acción no se puede deshacer.</p>
  528. </div>
  529. </div>
  530. </div>
  531. <div class="modal-footer">
  532. <input type="hidden" id="id_borrar" value="">
  533. <button type="button" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Borrar</button>
  534. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  535. </div>
  536. </div>
  537. </div>
  538. </div>
  539. </main>
  540. <? include "import/html_footer.php"; ?>
  541. <?php
  542. //--Manejo de errores y mensajes de exito
  543. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  544. switch ($_GET["error"]){
  545. case 0: $errorDesc = "No se reciberon los datos de la reposición."; break;
  546. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la reposición/cambio."; break;
  547. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la reposición/cambio."; break;
  548. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  549. case 4: $errorDesc = "Ocurrió un error al cargar los datos de la reposición/cambio."; break;
  550. case 6: $errorDesc = "La reposición/cambio que buscas no existe. Consulta la lista de reopsiciones disponibles en esta sección."; break;
  551. case 7: $errorDesc = "La reposición/cambio se empalma con el horario del grupo y no se puede guardar."; break;
  552. 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;
  553. case 9: $errorDesc = "El profesor está asigndo a otra clase o reposición el mismo día a la misma hora y no se puede guardar."; break;
  554. case 10: $errorDesc = "El profesor está asigndo a una materia el mismo día a la misma hora y no se puede guardar."; break;
  555. case 11: $errorDesc = "No hay clases asignadas para esa materia y grupo en la fecha de falta."; break;
  556. }
  557. }
  558. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  559. switch ($_GET["ok"]){
  560. case 0: $successDesc = "La reposición se guardó correctamente."; break;
  561. case 1: $successDesc = "La reposición se actualizó correctamente."; break;
  562. }
  563. }
  564. require_once 'js/messages.php';
  565. ?>
  566. <script>
  567. <?php if(isset($errorDesc)){ ?>
  568. triggerMessage("<?php echo $errorDesc;?>", "Error");
  569. <?php } else if(isset($successDesc)){ ?>
  570. triggerMessage("<?php echo $successDesc;?>", "Éxito", "success");
  571. <?php } ?>
  572. var vacaciones=[
  573. <?php
  574. $vacaciones_rs = $db->query('SELECT diasfestivos_dia from diasfestivos d where :periodo = any(d.periodos_id)', [':periodo' => $user->periodo_id ]);
  575. foreach($vacaciones_rs as $v){ echo '"'.$v["diasfestivos_dia"].'",';}
  576. ?>
  577. ];
  578. var _dias_asistencia = [];//ya registró asistencia, cambia con ajax
  579. var _dia_valido = 0;
  580. var _fecha_manhana = "<?php echo $fecha_man; ?>";
  581. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  582. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  583. var datepickerOptions_filtro = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final};
  584. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final,
  585. beforeShowDay: function(date) {
  586. var day = date.getDay();
  587. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  588. if (day === _dia_valido) {// 0 representa el domingo
  589. if (vacaciones.indexOf(dateString) !== -1 || _dias_asistencia.indexOf(dateString) !== -1)
  590. return [false];
  591. else
  592. return [true];
  593. }else{
  594. return [false];
  595. }
  596. }
  597. };
  598. var datepickerOptions_future = { dateFormat: "dd/mm/yy", minDate:_fecha_manhana, maxDate:_periodo_fecha_final,
  599. beforeShowDay: function(date) {
  600. var day = date.getDay();
  601. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  602. if (day === 0) {// 0 representa el domingo
  603. return [false];
  604. } else {
  605. if (vacaciones.indexOf(dateString) !== -1) {
  606. return [false];
  607. } else {
  608. return [true];
  609. }
  610. }
  611. }
  612. };
  613. function diaAAno(fecha_str){//de dd/mm/yyyy a yyyy-mm-dd
  614. if(fecha_str.charAt(2) == "/" && fecha_str.charAt(5) == "/"){//dd/mm/yyyy
  615. var fecha_arr = fecha_str.split("/");
  616. return fecha_arr[2]+"-"+fecha_arr[1]+"-"+fecha_arr[0];
  617. }
  618. return fecha_str;
  619. }
  620. function fechaMayor(fechaI, fechaF) {//cual es mayor >0 I mayor <0 F mayor
  621. return (Date.parse(diaAAno(fechaI)) - Date.parse(diaAAno(fechaF)));
  622. }
  623. function validaFechas(){
  624. if(fechaMayor($('#filtro_inicial').val().trim(), $('#filtro_final').val().trim()) > 0){
  625. $('#filtro_final').addClass("is-invalid");
  626. return false;
  627. }
  628. return true;
  629. }
  630. function submitForm(){
  631. var myBtn = $('#submitBtn');
  632. var error = false;
  633. $("#gpo").removeClass("is-invalid");
  634. invalidDatalist("#materia", false);
  635. $("#fecha_inicial").removeClass("is-invalid");
  636. $("#fecha_falta").removeClass("is-invalid");
  637. $("#fecha_cambio").removeClass("is-invalid");
  638. if($("#tipo").val() == 1){//reposición
  639. if($("#fecha_falta").val() == ""){
  640. $("#fecha_falta").addClass("is-invalid");
  641. error = true;
  642. }
  643. if($("#fecha_inicial").val() == ""){//fecha reposición
  644. $("#fecha_inicial").addClass("is-invalid");
  645. error = true;
  646. }
  647. }else{
  648. if($("#fecha_cambio").val() == ""){
  649. $("#fecha_cambio").addClass("is-invalid");
  650. error = true;
  651. }
  652. }
  653. if($("#horario").val().trim() == "" || $("#horario").val() === null){
  654. invalidDatalist("#horario", true);
  655. error = true;
  656. }
  657. if(myBtn.data("tipo") == 2 ){
  658. $('#formaModal').prop("action", "./action/reposicion_update.php");
  659. }else{
  660. $('#formaModal').prop("action", "./action/reposicion_insert.php");
  661. }
  662. return !error;
  663. }
  664. function cambiaTipo(tipo){
  665. if (tipo == 1){//reposición
  666. $(".repo_block").show();
  667. $(".cambio_block").hide();
  668. $(".repo_block").find("input[type=text]").attr("required", true);
  669. $(".cambio_block").find("input[type=text]").removeAttr("required");
  670. $("#hora_nombre").text("Hora reposición *");
  671. }else{//Cambio de salón
  672. $(".repo_block").hide();
  673. $(".cambio_block").show();
  674. $(".repo_block").find("input[type=text]").removeAttr("required");
  675. $(".cambio_block").find("input[type=text]").attr("required", true);
  676. $("#hora_nombre").text("Hora cambio *");
  677. var hora = $("#dlMateria ul li.selected").data("hr");
  678. var min = $("#dlMateria ul li.selected").data("min");
  679. $("#hora_ini").val(hora)
  680. $("#min_ini").val(min)
  681. }
  682. }
  683. $(document).ready(function(){
  684. $(".prof-selected").hide();
  685. //fecha de clase
  686. $(".date-picker" ).datepicker(datepickerOptions);
  687. $(".date-picker" ).datepicker( $.datepicker.regional[ "es" ] );
  688. //fecha de clase
  689. $(".date-picker-filtro" ).datepicker(datepickerOptions_filtro);
  690. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  691. //fecha nueva
  692. $(".date-picker-future" ).datepicker(datepickerOptions_future);
  693. $(".date-picker-future" ).datepicker( $.datepicker.regional[ "es" ] );
  694. function creaOpcion(id_horario, dia, hora, min, nombre, gpo, duracion){
  695. return '<li data-id="'+id_horario+'" data-dia="'+dia+'" data-hr="'+hora+'" data-min="'+min+'" data-gpo="'+gpo+'" data-duracion="'+duracion+'">'+nombre+'</li>';
  696. }
  697. $('#filtro_final').focus(function(){
  698. $("#filtro_final").removeClass("is-invalid");
  699. });
  700. function obtieneProf(pid){
  701. return $.ajax({
  702. url: './action/reposicion_profesor_materias.php',
  703. type: 'POST',
  704. dataType: 'json',
  705. data: { id: pid, },
  706. //async: false,
  707. success: function(result) {
  708. if(result["error"]!= "" && result["error"] !== undefined){
  709. triggerMessage(result["error"], "Error");
  710. $("#modal").modal('hide');
  711. $(".prof-selected").hide();
  712. }else{
  713. $(".prof-selected").show();
  714. $("#dlMateria ul").html("");
  715. for(i=0; i<result["materias"].length; i++){
  716. var html = creaOpcion(result["materias"][i]["horario_id"],
  717. result["materias"][i]["horario_dia"],
  718. result["materias"][i]["horario_hora"],
  719. result["materias"][i]["horario_min"],
  720. result["materias"][i]["materia_nombre"],
  721. result["materias"][i]["grupo"],
  722. result["materias"][i]["duracion"]
  723. );
  724. $("#dlMateria ul").append(html);
  725. }
  726. }
  727. },
  728. error: function(jqXHR, textStatus, errorThrown ){
  729. triggerMessage(errorThrown, "Error");
  730. }
  731. });//ajax
  732. }
  733. $(document).on( "click", "#dlProfesor ul li", function(event){//cambia datalist
  734. var pid = $(this).data('id');
  735. //busca materias del profesor
  736. var profCarga = obtieneProf(pid);
  737. profCarga.done(function(){
  738. $("#dlMateria ul li:first").click();
  739. });
  740. });
  741. //Actualiza días elegibles de calendario
  742. $(document).on( "click", "#dlMateria ul li", function(event){//manda al frente de todos
  743. _dia_valido = $(this).data('dia');//variable global
  744. var grupo = $(this).data("gpo");
  745. var duracionMateria = $(this).data("duracion");
  746. $(".date-picker" ).datepicker(datepickerOptions);
  747. var hora = $(this).data("hr");
  748. var min = $(this).data("min");
  749. $("#hora_ini").val(hora)
  750. $("#min_ini").val(min)
  751. return $.ajax({
  752. url: './action/asistenciasprofesor_select.php',
  753. type: 'POST',
  754. dataType: 'json',
  755. data: { "id": $("#prof").val(), "hor": $(this).data("id") },
  756. //async: false,
  757. success: function(result) {
  758. if(result["error"]!= "" && result["error"] !== undefined){
  759. triggerMessage(result["error"], "Error");
  760. $('#modal').modal("hide");
  761. }else{
  762. _dias_asistencia = result["asistenciaArr"];
  763. //Cambiar ciclo [6] y bloque [8]
  764. $("#ciclo").val(parseInt(grupo[6]));
  765. $("#bloque").val(parseInt(grupo[8])-1);
  766. $('#duracion option').each(function() {
  767. if ($(this).data("duracion") === duracionMateria) {
  768. // Selecciona la opción correspondiente en el select de "duracion"
  769. $(this).prop('selected', true);
  770. }
  771. });
  772. }
  773. },
  774. error: function(jqXHR, textStatus, errorThrown ){
  775. triggerMessage(errorThrown, "Error");
  776. }
  777. });//ajax
  778. });
  779. $("#dlTipo ul li").click(function(){//cambia datalist
  780. cambiaTipo($(this).data('id'));
  781. $(".date-picker" ).datepicker(datepickerOptions);
  782. });
  783. $('#modal_confirm').on('show.bs.modal', function (event) {
  784. var button = $(event.relatedTarget); // Button that triggered the modal
  785. var id = button.parents("tr").data("id");
  786. $("#id_borrar").val(id);
  787. });
  788. $(".btn-borrar").click(function(){
  789. var r_id = $("#id_borrar").val();
  790. $.ajax({
  791. url: './action/reposicion_delete.php',
  792. type: 'POST',
  793. dataType: 'json',
  794. data: { id: r_id},
  795. success: function(result) {
  796. if(result["error"]!= "" && result["error"] !== undefined){
  797. triggerMessage(result["error"], "Error");
  798. }else{
  799. triggerMessage(result["ok"], "Éxito", "success");
  800. $("#id"+r_id).remove();
  801. }
  802. },
  803. error: function(jqXHR, textStatus, errorThrown ){
  804. triggerMessage(errorThrown, "Error");
  805. }
  806. });//ajax
  807. $('#modal_confirm').modal("hide");
  808. });
  809. $('#modal').on('show.bs.modal', function (event) {
  810. var button = $(event.relatedTarget); // Button that triggered the modal
  811. var tipo = button.data('tipo'); // 1 alta, 2 edicion
  812. var modal = $(this);
  813. $("#modal .is-invalid").removeClass("is-invalid");
  814. //$(this).find(".form-control:first-child").focus();
  815. $("#errorBox").collapse('hide');
  816. $("#errorBox_text").html("");
  817. if(tipo == 1){//alta
  818. $("#submitBtn").data('tipo', 1);
  819. $("#modalLabel").html("Crear Reposición");
  820. modal.find("input[type=text]").val("");
  821. modal.find("#alumnos").val("15");
  822. $("#plan").attr("readonly", false);
  823. $("#sem").attr("readonly", false);
  824. $("#gpo").attr("readonly", false);
  825. //$("#prof").attr("readonly", false);
  826. disableDatalist("#horario", false);
  827. disableDatalist("#tipo", false);
  828. if($("#prof").length>0)
  829. disableDatalist("#prof", false);
  830. setDatalistFirst("#tipo");
  831. setDatalistFirst("#aula");
  832. setDatalistFirst("#horario");
  833. $("#dlMateria ul li:first").click();
  834. }else{//editar
  835. $("#submitBtn").data('tipo', 2);
  836. $("#modalLabel").html("Editar Reposición");
  837. $("#plan").attr("readonly", true);
  838. $("#sem").attr("readonly", true);
  839. $("#gpo").attr("readonly", true);
  840. //$("#materia").attr("readonly", true);
  841. disableDatalist("#horario");
  842. disableDatalist("#tipo");
  843. disableDatalist("#prof");
  844. /*if($("#prof").length>0)
  845. disableDatalist("#prof");
  846. $("#prof").attr("readonly", true);*/
  847. var r_id = $(button).parents("tr").data("id");
  848. $("#id").val(r_id);
  849. $.ajax({
  850. url: './action/reposicion_select.php',
  851. type: 'POST',
  852. dataType: 'json',
  853. data: { id: r_id },
  854. async: true,
  855. success: function(result) {
  856. if(result["error"]!= "" && result["error"] !== undefined){
  857. triggerMessage(result["error"], "Error");
  858. $("#modal").modal('hide');
  859. }else{
  860. //setDatalist("#prof", result["profesor"]);
  861. setDatalist("#prof", result["profesor"]);
  862. var profCarga = obtieneProf(result["profesor"]);
  863. //$('#salon').val(result["salon"]);
  864. $("#fecha_falta").val(result["fecha_clase"]);
  865. $('#hora_ini').val(result["hora_ini"]);
  866. $('#min_ini').val(result["min_ini"]);
  867. $('#comentario').val(result["comentario"]);
  868. $('#alumnos').val(result["alumnos"]);
  869. $('#ciclo').val(result["ciclo"]);
  870. $('#bloque').val(result["bloque"]);
  871. if(result["tipo"]){
  872. setDatalist("#tipo", 1);
  873. cambiaTipo(1);
  874. $("#fecha_inicial").val(result["fecha_nueva"]);
  875. }else{
  876. setDatalist("#tipo", 2);
  877. cambiaTipo(2);
  878. $("#fecha_cambio").val(result["fecha_nueva"]);
  879. }
  880. _dia_valido = parseInt(result["dia"]);
  881. $(".date-picker" ).datepicker(datepickerOptions);
  882. $("#dlTipo ul li:selected").click();
  883. profCarga.done(function(){
  884. setDatalist("#horario", result["horario"]);// No se actualiza TODO
  885. });
  886. setDatalist("#aula", result["aula"]);
  887. modal.modal('show');
  888. }
  889. },
  890. error: function(jqXHR, textStatus, errorThrown ){
  891. triggerMessage(errorThrown, "Error");
  892. $("#modal").modal('hide');
  893. //$('#messageBox')[0].scrollIntoView({ block: "end" });
  894. }
  895. });//ajax
  896. }
  897. });//show
  898. });
  899. $(function() {
  900. $('[data-toggle="tooltip"]').tooltip()
  901. })
  902. </script>
  903. <script src="js/messages.js"></script>
  904. <script type="module" src="js/reposiciones.js"></script>
  905. </body>
  906. </html>