solicitud_crear.php 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972
  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. if ($user->acceso === null && !$user->admin){
  10. die(header('Location: index.php'));
  11. exit();
  12. }
  13. //if (!$user->admin && in_array($user->acceso, ['n']))
  14. //die(header('Location: main.php?error=1'));
  15. //$user->print_to_log('Reposiciones');
  16. //$write = $user->admin || in_array($user->acceso, ['w']);
  17. $write = true; //
  18. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo_id])['esta_en_periodo'];
  19. if($user->jefe_carrera){
  20. //$prof_rs = $db->query('SELECT DISTINCT * FROM fs_profesores(null, null, :fac) ORDER BY PROFESOR_NOMBRE', [':fac' => $user->facultad["facultad_id"]]);
  21. $prof_rs = $db->query('SELECT DISTINCT PROFESOR.* FROM PUESTO_USUARIO
  22. JOIN PUESTO_MATERIA USING (PUESTO_ID)
  23. JOIN HORARIO_VIEW USING (MATERIA_ID)
  24. JOIN HORARIO_PROFESOR USING (HORARIO_ID)
  25. JOIN PROFESOR USING (PROFESOR_ID)
  26. WHERE USUARIO_ID = :usr', [':usr' => $user->user["id"]]);
  27. }else{
  28. $prof_rs = $db->query('SELECT DISTINCT PROFESOR.* FROM PROFESOR
  29. JOIN horario_profesor USING (profesor_id)
  30. JOIN HORARIO_VIEW USING (horario_id)
  31. WHERE FACULTAD_ID = :fac ORDER BY profesor.profesor_nombre', [':fac' => $user->facultad["facultad_id"]]);
  32. }
  33. //Duraciones
  34. $duracion_rs = $db->query("select * from duracion order by duracion_interval");
  35. $tiposol_rs = $db->query("select * from solicitudtipo order by solicitudtipo_id");
  36. if(!is_null($user->periodo_id)){
  37. //Obtiene datos de periodo
  38. $periodo_rs = $db->querySingle('SELECT periodo_fecha_inicio, periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id', [':periodo_id' => $user->periodo_id]);
  39. $periodo_fin = $periodo_rs["periodo_fecha_fin"];
  40. if(strtotime($periodo_rs["periodo_fecha_inicio"])>strtotime(date("Y-m-d")) )
  41. $fecha_man = date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"]));
  42. else{
  43. $dia_actual = intval(date("w"));
  44. $dias = 2;//días mínimos Lun a Jue
  45. if($dia_actual ==5 || $dia_actual ==4 )//Vie
  46. $dias=4;
  47. else if( $dia_actual ==6 )//Sab
  48. $dias=3;
  49. else if( $dia_actual ==0 )//Do
  50. $dias=2;
  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>Solicitudes 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("Registro de solicitudes", "Sistema de gestión de checador");
  107. ?>
  108. <main class="container content marco content-margin" id="local-app">
  109. <?php
  110. if($write==true && isset($prof_rs) && count($prof_rs)>0) {?>
  111. <!-- Botón para abrir el modal -->
  112. <div class="row mb-4">
  113. <div class="col-12 text-center">
  114. <div class="btn-group" role="group">
  115. <?php foreach ($tiposol_rs as $tipo){ ?>
  116. <button type="button" class="btn btn-outline-primary" data-accion="1" data-tipo="<?php echo $tipo["solicitudtipo_id"];?>" data-toggle="modal" data-target="#modal" <?php if (!$en_fecha ) { echo "disabled"; } ?>><span class="ing-mas ing-fw"></span><?php echo $tipo["solicitudtipo_nombre"];?></button>
  117. <?php } ?>
  118. </div>
  119. </div>
  120. </div>
  121. <?php }?>
  122. <section id="message"></section>
  123. <?php require('import/periodo.php') ?>
  124. <?php if(!is_null($user->periodo_id)) { ?>
  125. <form id="asistencia" method="post" onsubmit="return validaFechas()">
  126. <div class="form-box">
  127. <input type="hidden" name="facultad" value="">
  128. <div class="form-group row">
  129. <label for="filtro_inicial" class="col-4 col-form-label">Fecha inicial</label>
  130. <div class="col-8 col-sm-4">
  131. <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;?>">
  132. <div class="invalid-feedback">No es una fecha válida.</div>
  133. </div>
  134. </div>
  135. <div class="form-group row">
  136. <label for="filtro_final" class="col-4 col-form-label">Fecha final</label>
  137. <div class="col-8 col-sm-4">
  138. <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;?>">
  139. <div class="invalid-feedback">El rango de fechas no es válido.</div>
  140. </div>
  141. </div>
  142. </div>
  143. <div class="form-group row justify-content-center">
  144. <button type="submit" class="btn btn-outline-primary mr-2" id="btn-buscar"><span class="ing-buscar ing-fw"></span> Buscar</button>
  145. <button type="button" class="btn btn-outline-danger" onclick="window.location.href = window.location.href"><span class="ing-borrar ing-fw"></span> Limpiar</button>
  146. </div>
  147. </form>
  148. <?php
  149. $reposiciones_rs = $db->query('SELECT * FROM fs_solicitud(NULL, NULL, NULL, :f_ini, :f_fin, NULL, :usr, null)', [':f_ini' => $fecha_ini_db, ':f_fin' => $fecha_fin_db, ':usr' => $user->user["id"]]);
  150. }
  151. ?>
  152. <div class="row">
  153. <?php
  154. if(isset($reposiciones_rs) && count($reposiciones_rs)>0){ ?>
  155. <h3 class="mb-3">Solicitudes creadas</h3>
  156. <div class="col-12 table-responsive px-0">
  157. <table class="table table-sm table-striped table-white">
  158. <thead class="thead-dark">
  159. <tr >
  160. <th>Estado</th>
  161. <th>Tipo</th>
  162. <th>Materia</th>
  163. <th style="width:160px">Fecha original</th>
  164. <th style="width:160px">Fecha nueva</th>
  165. <th style="width:160px">Duración</th>
  166. <th>Salón</th>
  167. <?php if($write){ ?><th>Acciones</th><?php } ?>
  168. </tr>
  169. </thead>
  170. <tbody>
  171. <?php
  172. foreach($reposiciones_rs as $reposicion){
  173. ?>
  174. <tr data-id="<?php echo $reposicion["solicitud_id"]; ?>" id="id<?php echo $reposicion["solicitud_id"]; ?>">
  175. <td class="align-middle text-center" style="color:<?php echo $reposicion["estado_color"];?>" title="<?php echo $reposicion["estado_nombre"];?>">
  176. <?php if($reposicion["estado_reposicion_id"] < 3){ ?>
  177. <div class="wizard <?php if(intval($reposicion["estado_reposicion_id"])==2) echo "active";?> d-flex mx-auto">
  178. <div class="w-50 h-100"></div>
  179. <div class=""></div>
  180. </div>
  181. <?php } else if($reposicion["estado_reposicion_id"]==3){?>
  182. <div class="text-success text-center pt-1">
  183. <span class="ing-autorizar ing-lg"></span>
  184. </div>
  185. <?php } else {?>
  186. <div class="text-danger text-center pt-1">
  187. <span class="ing-negar ing-lg"></span>
  188. </div>
  189. <?php } ?>
  190. </td>
  191. <td class="align-middle">
  192. <?php echo $reposicion["solicitudtipo_nombre"]; ?>
  193. </td>
  194. <td class="align-middle">
  195. <?php echo $reposicion["materia_nombre"]=="" ? "-":$reposicion["materia_nombre"]; ?>
  196. <br>
  197. <small class="text-info"><?php echo $reposicion["profesor_nombre"]; ?></small>
  198. </td>
  199. <td class="align-middle text-center"><?php
  200. if($reposicion["fecha_clase"] == "") echo "-";
  201. else
  202. 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.";;
  203. ?>
  204. </td>
  205. <td class="align-middle text-center"><?php
  206. 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.";
  207. ?>
  208. </td>
  209. <td class="align-middle text-center"><?php
  210. echo $reposicion["duracion_interval"];
  211. ?>
  212. </td>
  213. <td class="align-middle text-center"><?php
  214. if($reposicion["salon_id"] != ""){
  215. echo $reposicion["salon_nombre"];
  216. }else
  217. echo "Pendiente";
  218. ?>
  219. </td>
  220. <?php if($write){ ?>
  221. <td class="align-middle text-center icono-acciones">
  222. <?php
  223. //no se ha aprobado
  224. if(($reposicion["estado_reposicion_id"] == 1 && $user->jefe_carrera) || ($reposicion["estado_reposicion_id"] == 2 && !$user->jefe_carrera)){?>
  225. <a href="#" data-accion="2" data-tipo="<?php echo $reposicion["solicitudtipo_id"]; ?>" title="Editar" data-toggle="modal" data-target="#modal"><?php echo $ICO["editar"];?></a>
  226. <a href="#" data-toggle="modal" data-target="#modal_confirm" title="Borrar"><?php echo $ICO["cancelar"];?></a>
  227. <?php } ?>
  228. </td>
  229. <?php } ?>
  230. </tr>
  231. <?php }
  232. ?>
  233. </tbody>
  234. </table>
  235. </div>
  236. <?php } else {
  237. if(is_null($user->periodo_id)){ ?>
  238. <div class="col-12 text-center">
  239. <h4 class="mt-4 text-danger">Selecciona un periodo</h4>
  240. </div>
  241. <?php } else {?>
  242. <div class="col-12 text-center">
  243. <h4 class="mt-4 text-danger">No tienes solicitudes disponibles que cumplan con los filtros</h4>
  244. </div>
  245. <?php }
  246. } ?>
  247. </div>
  248. <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  249. <div class="modal-dialog modal-dialog-centered modal-xl" role="document">
  250. <div class="modal-content">
  251. <div class="modal-header">
  252. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Crear solicitud</span>
  253. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  254. <span aria-hidden="true">&times;</span>
  255. </button></h4>
  256. </div>
  257. <div class="modal-body">
  258. <form action="" method="post" id="formaModal" onsubmit="return submitForm()">
  259. <input type="hidden" name="id" id="id">
  260. <input type="hidden" name="estado" value="1">
  261. <input type="hidden" name="ciclo" id="ciclo" value="0">
  262. <input type="hidden" name="bloque" id="bloque" value="0">
  263. <input type="hidden" name="tipo" id="tipo" value="1">
  264. <div class="form-box">
  265. <div class="form-group row" id="profBlock">
  266. <label for="prof" class="col-4 col-form-label">Profesor *</label>
  267. <div class="col-8">
  268. <div class="datalist datalist-select mb-1 w-100" id="dlProfesor">
  269. <div class="datalist-input">Selecciona un profesor</div>
  270. <span class="ing-buscar icono"></span>
  271. <ul style="display:none">
  272. <?php foreach($prof_rs as $prof){?>
  273. <li data-id="<?php echo $prof["profesor_id"];?>" <?php if($prof["profesor_id"]==$user->profesor){ echo "class='selected'";} ?> ><?php echo $prof["profesor_nombre"];?></li>
  274. <?php } ?>
  275. </ul>
  276. <input type="hidden" id="prof" name="prof" value="">
  277. </div>
  278. </div>
  279. </div>
  280. </div>
  281. <div class="form-box prof-selected">
  282. <div class="form-group row" id="materiaBlock">
  283. <label for="horario" class="col-4 col-form-label">Materia *</label>
  284. <div class="col-8">
  285. <div class="datalist datalist-select mb-1 w-100" id="dlMateria">
  286. <div class="datalist-input">Selecciona una materia</div>
  287. <span class="ing-buscar icono"></span>
  288. <ul style="display:none">
  289. </ul>
  290. <input type="hidden" id="horario" name="horario" value="">
  291. </div>
  292. </div>
  293. </div>
  294. <div class="form-group row materia-block">
  295. <label for="duracion" class="col-4 col-form-label">Duración</label>
  296. <div class="col-4">
  297. <select name="duracion" id="duracion" class="form-control" required="required">
  298. <?php foreach($duracion_rs as $dura){?>
  299. <option value="<?php echo $dura["duracion_id"];?>" data-duracion="<?php echo $dura["duracion_interval"];?>" ><?php echo $dura["duracion_nombre"];?></option>
  300. <?php } ?>
  301. </select>
  302. </div>
  303. </div>
  304. <div class="form-group row cambio_block materia-block" style="display: none;">
  305. <label for="fecha_cambio" class="col-4 col-form-label">Fecha de cambio *</label>
  306. <div class="col-8">
  307. <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="">
  308. </div>
  309. </div>
  310. <div class="form-group row repo_block materia-block">
  311. <label for="fecha_falta" class="col-4 col-form-label">Fecha de falta *</label>
  312. <div class="col-8">
  313. <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="">
  314. </div>
  315. </div>
  316. <div class="form-group row repo_block materia-block">
  317. <label for="fecha_nueva" class="col-4 col-form-label">Fecha nueva *</label>
  318. <div class="col-8">
  319. <input id="fecha_nueva" name="fecha_nueva" type="text" class="form-control date-picker-future" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="readonly" value="">
  320. <small class="form-text text-muted">Las solicitudes se deben hacer con al menos 48hrs de anticipación.<br>
  321. Recuerda que en sábado el límite para terminar la clase es a las 15:00hrs.
  322. </small>
  323. </div>
  324. </div>
  325. <div class="form-group row materia-block">
  326. <label for="hora_ini" class="col-4 col-form-label" id="hora_nombre">Hora nueva *</label>
  327. <?php
  328. //define("HORA_FINAL", 22);
  329. //define("FRACCION_HORA", 15);
  330. $default_h = 7; $default_m = 15;
  331. ?>
  332. <div class="col-4">
  333. <select name="hora_ini" id="hora_ini" class="form-control" required="required">
  334. <?php for($h = $default_h; $h < HORA_FINAL; $h++){?>
  335. <option value="<?php echo sprintf( '%02d', $h );?>" <?php if($default_h == $h){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $h );?></option>
  336. <?php } ?>
  337. </select>
  338. </div>
  339. <div class="col-4">
  340. <select name="min_ini" id="min_ini" class="form-control" required="required">
  341. <?php for($m = 0; $m < 60; $m+=(60/FRACCION_HORA)){?>
  342. <option value="<?php echo sprintf( '%02d', $m );?>" <?php if($default_m == $m){ echo 'selected="selected"';}?>><?php echo sprintf( '%02d', $m );?></option>
  343. <?php } ?>
  344. </select>
  345. </div>
  346. </div>
  347. <div class="form-group row materia-block">
  348. <label for="salon" class="col-4 col-form-label">Alumnos aproximados *</label>
  349. <div class="col-8 col-md-4">
  350. <input type="number" name="alumnos" id="alumnos" class="form-control" value="1" min="1" max="50">
  351. </div>
  352. </div>
  353. <div class="form-group row materia-block">
  354. <label for="aula" class="col-4 col-form-label">Tipo aula *</label>
  355. <div class="col-8">
  356. <div class="datalist datalist-select mb-1 w-100" id="dlAula">
  357. <div class="datalist-input">Salón</div>
  358. <span class="ing-buscar icono"></span>
  359. <ul style="display:none">
  360. <?php
  361. $tipoaula_rs = $db->query('select * from tipoaula t order by t.tipoaula_id ');
  362. foreach($tipoaula_rs as $ta){ ?>
  363. <li data-id="<?php echo $ta["tipoaula_id"];?>"><?php echo $ta["tipoaula_nombre"];?></li>
  364. <?php } ?>
  365. </ul>
  366. <input type="hidden" id="aula" name="aula" value="1">
  367. </div>
  368. </div>
  369. </div>
  370. <?php if(!$user->jefe_carrera){//es coordinador
  371. $salones_rs = $db->query('SELECT * from salon_view where es_salon is true');
  372. ?>
  373. <div class="row" id="salon-editar" style="display: none;">
  374. <div class="col-6 col-sm-4 barra-right text-right">
  375. <p class="font-weight-bold">Salón *</p>
  376. </div>
  377. <div class="col-6">
  378. <input list="lista_salones" name="dlSalon" id="dlSalon" class="form-control" placeholder="Salón">
  379. <div class="valid-feedback">
  380. Salón encontrado
  381. </div>
  382. <div class="invalid-feedback">
  383. Salón no encontrado
  384. </div>
  385. <datalist id="lista_salones">
  386. <?php
  387. foreach ($salones_rs as $salon) {
  388. extract($salon);
  389. $salon_json = json_decode($salon_array, true);
  390. if($salon_json[0]== "UNIVERSIDAD LA SALLE"){
  391. unset($salon_json[0]);
  392. }
  393. $salon_nombre = join(" / ",$salon_json);
  394. ?>
  395. <option data-id="<?= $salon_id ?>" data-nombre="<?= $salon_nombre ?>" value="<?= $salon_nombre ?>"></option>
  396. <?php
  397. }
  398. ?>
  399. </datalist>
  400. <!-- <ul class="list-group" id="salones"></ul> -->
  401. <input type="hidden" id="salon" name="salon" value="">
  402. </div>
  403. </div>
  404. <?php } ?>
  405. <div class="form-group row materia-block">
  406. <label for="comentario" class="col-4 col-form-label">Comentarios</label>
  407. <div class="col-8">
  408. <p><i>Requerimientos específicos del salón, software especializado, etc.</i></p>
  409. <textarea rows="3" class="form-control" id="comentario" name="comentario"></textarea>
  410. </div>
  411. </div>
  412. </div>
  413. <div class="form-group row mt-3" id="submitGroup">
  414. <div class="offset-4 col-8">
  415. <button type="submit" class="btn btn-outline-primary materia-block" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  416. <button type="reset" class="btn btn-outline-danger" data-dismiss="modal"><?php echo $ICO["cancelar"];?> Cancelar</button>
  417. </div>
  418. </div>
  419. <div class="form-group row mt-3" id="loadingGroup" style="display:none">
  420. <div class="col-12 text-center">
  421. <div class="spinner-border text-primary" role="status">
  422. <span class="sr-only">Loading...</span>
  423. </div>
  424. </div>
  425. </div>
  426. </form>
  427. </div>
  428. </div>
  429. </div>
  430. </div>
  431. <!-- Modal del formulario -->
  432. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  433. <div class="modal-dialog modal-dialog-centered" role="document">
  434. <div class="modal-content">
  435. <div class="modal-body">
  436. <div class="row">
  437. <div class="col">
  438. <p class="font-weight-bold">¿Estás seguro de que quieres borrar la solicitud?</p>
  439. <p>Esta acción no se puede deshacer.</p>
  440. </div>
  441. </div>
  442. </div>
  443. <div class="modal-footer">
  444. <input type="hidden" id="id_borrar" value="">
  445. <button type="button" class="btn btn-outline-primary btn-borrar"><?php echo $ICO["aceptar"];?> Borrar</button>
  446. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  447. </div>
  448. </div>
  449. </div>
  450. </div>
  451. </main>
  452. <? include "import/html_footer.php"; ?>
  453. <?php
  454. //--Manejo de errores y mensajes de exito
  455. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  456. switch ($_GET["error"]){
  457. case 0: $errorDesc = "No se reciberon los datos de la reposición."; break;
  458. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la solicitud."; break;
  459. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la solicitud."; break;
  460. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  461. case 4: $errorDesc = "Ocurrió un error al cargar los datos de la solicitud."; break;
  462. case 6: $errorDesc = "La solicitud que buscas no existe. Consulta la lista de solicitudes disponibles en esta sección."; break;
  463. case 7: $errorDesc = "La solicitud se empalma con el horario del grupo y no se puede guardar."; break;
  464. case 8: $errorDesc = "El salón de la solicitud está siendo utilizado ese día a esa hora y no se puede guardar."; break;
  465. 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;
  466. case 10: $errorDesc = "El profesor está asigndo a una materia el mismo día a la misma hora y no se puede guardar."; break;
  467. case 11: $errorDesc = "No hay clases asignadas para esa materia y grupo en la fecha de falta."; break;
  468. }
  469. }
  470. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  471. switch ($_GET["ok"]){
  472. case 0: $successDesc = "La reposición se guardó correctamente."; break;
  473. case 1: $successDesc = "La reposición se actualizó correctamente."; break;
  474. }
  475. }
  476. require_once 'js/messages.php';
  477. ?>
  478. <script>
  479. <?php if(isset($errorDesc)){ ?>
  480. triggerMessage("<?php echo $errorDesc;?>", "Error");
  481. <?php } else if(isset($successDesc)){ ?>
  482. triggerMessage("<?php echo $successDesc;?>", "Éxito", "success");
  483. <?php } ?>
  484. var vacaciones=[
  485. <?php
  486. $vacaciones_rs = $db->query('SELECT diasfestivos_dia from diasfestivos d where :periodo = any(d.periodos_id)', [':periodo' => $user->periodo_id ]);
  487. foreach($vacaciones_rs as $v){ echo '"'.$v["diasfestivos_dia"].'",';}
  488. ?>
  489. ];
  490. var _dias_asistencia = [];//ya registró asistencia, cambia con ajax
  491. var _dia_valido = 0;
  492. var _fecha_manhana = "<?php echo $fecha_man; ?>";
  493. var _periodo_fecha_inicial = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_inicio"])); ?>";
  494. var _periodo_fecha_final = "<?php echo date("d/m/Y", strtotime($periodo_rs["periodo_fecha_fin"])); ?>";
  495. var datepickerOptions_filtro = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final};
  496. var tiposolicitud = <?php echo json_encode($tiposol_rs); ?>;
  497. var datepickerOptions = { dateFormat: "dd/mm/yy", minDate:_periodo_fecha_inicial, maxDate:_periodo_fecha_final,
  498. beforeShowDay: function(date) {
  499. var day = date.getDay();
  500. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  501. if (day === _dia_valido) {// 0 representa el domingo
  502. if (vacaciones.indexOf(dateString) !== -1 || _dias_asistencia.indexOf(dateString) !== -1)
  503. return [false];
  504. else
  505. return [true];
  506. }else{
  507. return [false];
  508. }
  509. }
  510. };
  511. var datepickerOptions_future = { dateFormat: "dd/mm/yy", minDate:_fecha_manhana, maxDate:_periodo_fecha_final,
  512. beforeShowDay: function(date) {
  513. var day = date.getDay();
  514. var dateString = $.datepicker.formatDate("yy-mm-dd", date);
  515. if (day === 0) {// 0 representa el domingo
  516. return [false];
  517. } else {
  518. if (vacaciones.indexOf(dateString) !== -1) {
  519. return [false];
  520. } else {
  521. return [true];
  522. }
  523. }
  524. }
  525. };
  526. function diaAAno(fecha_str){//de dd/mm/yyyy a yyyy-mm-dd
  527. if(fecha_str.charAt(2) == "/" && fecha_str.charAt(5) == "/"){//dd/mm/yyyy
  528. var fecha_arr = fecha_str.split("/");
  529. return fecha_arr[2]+"-"+fecha_arr[1]+"-"+fecha_arr[0];
  530. }
  531. return fecha_str;
  532. }
  533. function fechaMayor(fechaI, fechaF) {//cual es mayor >0 I mayor <0 F mayor
  534. return (Date.parse(diaAAno(fechaI)) - Date.parse(diaAAno(fechaF)));
  535. }
  536. function validaFechas(){
  537. if(fechaMayor($('#filtro_inicial').val().trim(), $('#filtro_final').val().trim()) > 0){
  538. $('#filtro_final').addClass("is-invalid");
  539. return false;
  540. }
  541. return true;
  542. }
  543. function submitForm(){
  544. var myBtn = $('#submitBtn');
  545. var error = false;
  546. $("#gpo").removeClass("is-invalid");
  547. invalidDatalist("#materia", false);
  548. $("#fecha_nueva").removeClass("is-invalid");
  549. $("#fecha_falta").removeClass("is-invalid");
  550. $("#fecha_cambio").removeClass("is-invalid");
  551. if($('#fecha_falta').is(':required') && $("#fecha_falta").val() == ""){
  552. $("#fecha_falta").addClass("is-invalid");
  553. error = true;
  554. }
  555. if($('#fecha_nueva').is(':required') && $("#fecha_nueva").val() == ""){//fecha reposición
  556. $("#fecha_nueva").addClass("is-invalid");
  557. error = true;
  558. }
  559. if($('#fecha_cambio').is(':required') && $("#fecha_cambio").val() == ""){
  560. $("#fecha_cambio").addClass("is-invalid");
  561. error = true;
  562. }
  563. if($("#horario").val().trim() == "" || $("#horario").val() === null){
  564. invalidDatalist("#horario", true);
  565. error = true;
  566. }
  567. if(myBtn.data("tipo") == 2 ){
  568. $('#formaModal').prop("action", "./action/solicitud_update.php");
  569. }else{
  570. $('#formaModal').prop("action", "./action/solicitud_insert.php");
  571. }
  572. if(!error){
  573. $("#loadingGroup").show();
  574. $("#submitGroup").hide();
  575. }
  576. return !error;
  577. }
  578. //cambia visibilidades de campos
  579. function cambiaTipo(tipo){
  580. $('#fecha_cambio').val("");
  581. $('#fecha_falta').val("");
  582. $('#fecha_nueva').val("");
  583. $("#tipo").val(tipo);
  584. switch(tipo){
  585. case 1://reposición
  586. $('#fecha_cambio').parents('.row').hide();
  587. $('#fecha_falta').parents('.row').show();
  588. $('#fecha_nueva').parents('.row').show();
  589. $("#hora_nombre").parents('.row').show();
  590. $('#fecha_cambio').removeAttr("required");
  591. $('#fecha_falta').attr("required", true);
  592. $('#fecha_nueva').attr("required", true);
  593. $("#hora_nombre").text("Hora reposición *");
  594. $("#materiaBlock").show();
  595. break;
  596. case 2://cambio de salón
  597. $('#fecha_cambio').parents('.row').show();
  598. $('#fecha_falta').parents('.row').hide();
  599. $('#fecha_nueva').parents('.row').hide();
  600. $("#hora_nombre").parents('.row').hide();
  601. $('#fecha_cambio').attr("required", true);
  602. $('#fecha_falta').removeAttr("required");
  603. $('#fecha_nueva').removeAttr("required");
  604. $("#materiaBlock").show();
  605. var hora = $("#dlMateria ul li.selected").data("hr");
  606. var min = $("#dlMateria ul li.selected").data("min");
  607. $("#hora_ini").val(hora);
  608. $("#min_ini").val(min);
  609. break;
  610. case 3:
  611. $('#fecha_cambio').parents('.row').hide();
  612. $('#fecha_falta').parents('.row').hide();
  613. $('#fecha_nueva').parents('.row').show();
  614. $("#hora_nombre").parents('.row').show();
  615. $('#fecha_cambio').removeAttr("required");
  616. $('#fecha_falta').removeAttr("required");
  617. $('#fecha_nueva').attr("required", true);
  618. $("#hora_nombre").text("Hora *");
  619. $("#materiaBlock").hide();
  620. break;
  621. case 4:
  622. $('#fecha_cambio').parents('.row').show();
  623. $('#fecha_falta').parents('.row').hide();
  624. $('#fecha_nueva').parents('.row').show();
  625. $("#hora_nombre").parents('.row').show();
  626. $('#fecha_cambio').attr("required", true);
  627. $('#fecha_falta').removeAttr("required");
  628. $('#fecha_nueva').attr("required", true);
  629. $("#hora_nombre").text("Hora cambio *");
  630. $("#materiaBlock").show();
  631. break;
  632. }
  633. }
  634. $(document).ready(function(){
  635. $(".prof-selected").hide();
  636. //fecha de clase
  637. $(".date-picker" ).datepicker(datepickerOptions);
  638. $(".date-picker" ).datepicker( $.datepicker.regional[ "es" ] );
  639. //fecha de clase
  640. $(".date-picker-filtro" ).datepicker(datepickerOptions_filtro);
  641. $(".date-picker-filtro" ).datepicker( $.datepicker.regional[ "es" ] );
  642. //fecha nueva
  643. $(".date-picker-future" ).datepicker(datepickerOptions_future);
  644. $(".date-picker-future" ).datepicker( $.datepicker.regional[ "es" ] );
  645. function creaOpcion(id_horario, dia, hora, min, nombre, gpo, duracion){
  646. return '<li data-id="'+id_horario+'" data-dia="'+dia+'" data-hr="'+hora+'" data-min="'+min+'" data-gpo="'+gpo+'" data-duracion="'+duracion+'">'+nombre+'</li>';
  647. }
  648. $('#filtro_final').focus(function(){
  649. $("#filtro_final").removeClass("is-invalid");
  650. });
  651. function obtieneProf(pid){
  652. return $.ajax({
  653. url: './action/reposicion_profesor_materias.php',
  654. type: 'POST',
  655. dataType: 'json',
  656. data: { id: pid, },
  657. //async: false,
  658. success: function(result) {
  659. if(result["error"]!= "" && result["error"] !== undefined){
  660. triggerMessage(result["error"], "Error");
  661. $("#modal").modal('hide');
  662. $(".prof-selected").hide();
  663. }else{
  664. $(".prof-selected").show();
  665. $("#dlMateria ul").html("");
  666. for(i=0; i<result["materias"].length; i++){
  667. var html = creaOpcion(result["materias"][i]["horario_id"],
  668. result["materias"][i]["horario_dia"],
  669. result["materias"][i]["horario_hora"],
  670. result["materias"][i]["horario_min"],
  671. result["materias"][i]["materia_nombre"],
  672. result["materias"][i]["grupo"],
  673. result["materias"][i]["duracion"]
  674. );
  675. $("#dlMateria ul").append(html);
  676. }
  677. }
  678. },
  679. error: function(jqXHR, textStatus, errorThrown ){
  680. triggerMessage(errorThrown, "Error");
  681. }
  682. });//ajax
  683. }
  684. $(document).on( "click", "#dlProfesor ul li", function(event){//cambia datalist
  685. var pid = $(this).data('id');
  686. //busca materias del profesor
  687. var profCarga = obtieneProf(pid);
  688. profCarga.done(function(){
  689. $("#dlMateria ul li:first").click();
  690. });
  691. });
  692. //Actualiza días elegibles de calendario
  693. $(document).on( "click", "#dlMateria ul li", function(event){//manda al frente de todos
  694. _dia_valido = $(this).data('dia');//variable global
  695. var grupo = $(this).data("gpo");
  696. var duracionMateria = $(this).data("duracion");
  697. $(".date-picker" ).datepicker(datepickerOptions);
  698. var hora = $(this).data("hr");
  699. var min = $(this).data("min");
  700. $("#hora_ini").val(hora)
  701. $("#min_ini").val(min)
  702. return $.ajax({
  703. url: './action/asistenciasprofesor_select.php',
  704. type: 'POST',
  705. dataType: 'json',
  706. data: { "id": $("#prof").val(), "hor": $(this).data("id") },
  707. //async: false,
  708. success: function(result) {
  709. if(result["error"]!= "" && result["error"] !== undefined){
  710. triggerMessage(result["error"], "Error");
  711. $('#modal').modal("hide");
  712. }else{
  713. _dias_asistencia = result["asistenciaArr"];
  714. //Cambiar ciclo [6] y bloque [8]
  715. $("#ciclo").val(parseInt(grupo[6]));
  716. $("#bloque").val(parseInt(grupo[8]));
  717. $('#duracion option').each(function() {
  718. if ($(this).data("duracion") === duracionMateria) {
  719. // Selecciona la opción correspondiente en el select de "duracion"
  720. $(this).prop('selected', true);
  721. }
  722. });
  723. }
  724. },
  725. error: function(jqXHR, textStatus, errorThrown ){
  726. triggerMessage(errorThrown, "Error");
  727. }
  728. });//ajax
  729. });
  730. $("#dlAula ul li").click(function(){//cambia datalist
  731. if($(this).data("id") == 1){
  732. $("#salon-editar").hide();
  733. $("#dlSalon").val("");
  734. $("#salon").val("");
  735. }else{
  736. $("#salon-editar").show();
  737. }
  738. });
  739. $('#modal_confirm').on('show.bs.modal', function (event) {
  740. var button = $(event.relatedTarget); // Button that triggered the modal
  741. var id = button.parents("tr").data("id");
  742. $("#id_borrar").val(id);
  743. });
  744. $(".btn-borrar").click(function(){
  745. var r_id = $("#id_borrar").val();
  746. $.ajax({
  747. url: './action/solicitud_delete.php',
  748. type: 'POST',
  749. dataType: 'json',
  750. data: { id: r_id},
  751. success: function(result) {
  752. if(result["error"]!= "" && result["error"] !== undefined){
  753. triggerMessage(result["error"], "Error");
  754. }else{
  755. triggerMessage(result["ok"], "Éxito", "success");
  756. $("#id"+r_id).remove();
  757. }
  758. },
  759. error: function(jqXHR, textStatus, errorThrown ){
  760. triggerMessage(errorThrown, "Error");
  761. }
  762. });//ajax
  763. $('#modal_confirm').modal("hide");
  764. });
  765. $('#modal').on('show.bs.modal', function (event) {
  766. var button = $(event.relatedTarget); // Button that triggered the modal
  767. var tipo = button.data('tipo');
  768. var accion = button.data('accion'); // 1 alta, 2 edicion
  769. var modal = $(this);
  770. $("#loadingGroup").hide();
  771. $("#submitGroup").show();
  772. $("#modal .is-invalid").removeClass("is-invalid");
  773. //$(this).find(".form-control:first-child").focus();
  774. cambiaTipo(tipo);
  775. $("#errorBox").collapse('hide');
  776. $("#errorBox_text").html("");
  777. if(accion == 1){//alta
  778. $("#submitBtn").data('tipo', 1);
  779. $("#modalLabel").html("Crear "+tiposolicitud[tipo-1]["solicitudtipo_nombre"]);
  780. modal.find("input[type=text]").val("");
  781. modal.find("#alumnos").val("15");
  782. $("#plan").attr("readonly", false);
  783. $("#sem").attr("readonly", false);
  784. $("#gpo").attr("readonly", false);
  785. //$("#prof").attr("readonly", false);
  786. disableDatalist("#horario", false);
  787. disableDatalist("#tipo", false);
  788. if($("#prof").length>0)
  789. disableDatalist("#prof", false);
  790. setDatalistFirst("#tipo");
  791. setDatalistFirst("#aula");
  792. setDatalistFirst("#horario");
  793. $("#dlMateria ul li:first").click();
  794. }else{//editar
  795. $("#submitBtn").data('tipo', 2);
  796. $("#modalLabel").html("Editar "+tiposolicitud[tipo-1]["solicitudtipo_nombre"]);
  797. $("#plan").attr("readonly", true);
  798. $("#sem").attr("readonly", true);
  799. $("#gpo").attr("readonly", true);
  800. //$("#materia").attr("readonly", true);
  801. disableDatalist("#horario");
  802. disableDatalist("#tipo");
  803. disableDatalist("#prof");
  804. /*if($("#prof").length>0)
  805. disableDatalist("#prof");
  806. $("#prof").attr("readonly", true);*/
  807. var r_id = $(button).parents("tr").data("id");
  808. $("#id").val(r_id);
  809. $.ajax({
  810. url: './action/solicitud_select.php',
  811. type: 'POST',
  812. dataType: 'json',
  813. data: { id: r_id },
  814. async: true,
  815. success: function(result) {
  816. if(result["error"]!= "" && result["error"] !== undefined){
  817. triggerMessage(result["error"], "Error");
  818. $("#modal").modal('hide');
  819. }else{
  820. cambiaTipo(result["solicitudtipo_id"]);
  821. //setDatalist("#prof", result["profesor"]);
  822. setDatalist("#prof", result["profesor"]);
  823. var profCarga = obtieneProf(result["profesor"]);
  824. //$('#salon').val(result["salon"]);
  825. $("#fecha_falta").val(result["fecha_clase"]);
  826. $('#comentario').val(result["comentario"]);
  827. $('#alumnos').val(result["alumnos"]);
  828. $('#ciclo').val(result["ciclo"]);
  829. $('#bloque').val(result["bloque"]);
  830. $("#tipo", result["solicitudtipo_id"]);
  831. if(result["solicitudtipo_id"]==2){
  832. $("#fecha_cambio").val(result["fecha_nueva"]);
  833. }else{
  834. $("#fecha_nueva").val(result["fecha_nueva"]);
  835. }
  836. _dia_valido = parseInt(result["dia"]);
  837. $(".date-picker" ).datepicker(datepickerOptions);
  838. $("#dlTipo ul li:selected").click();
  839. profCarga.done(function(){
  840. setDatalist("#horario", result["horario"]);// No se actualiza TODO
  841. $('#hora_ini').val(result["hora_ini"]);
  842. $('#min_ini').val(result["min_ini"]);
  843. });
  844. setDatalist("#aula", result["aula"]);
  845. modal.modal('show');
  846. }
  847. },
  848. error: function(jqXHR, textStatus, errorThrown ){
  849. triggerMessage(errorThrown, "Error");
  850. $("#modal").modal('hide');
  851. //$('#messageBox')[0].scrollIntoView({ block: "end" });
  852. }
  853. });//ajax
  854. }
  855. });//show
  856. });
  857. $(function() {
  858. $('[data-toggle="tooltip"]').tooltip()
  859. })
  860. </script>
  861. <script src="js/messages.js"></script>
  862. </body>
  863. </html>