reposiciones.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. <?php
  2. require_once 'class/c_login.php';
  3. $user = Login::get_user();
  4. $user->access();
  5. if (in_array($user->acceso, ['n']))
  6. die(header('Location: main.php?error=1'));
  7. $user->print_to_log('Consultar horario');
  8. $write = $user->admin || in_array($user->acceso, ['w']);
  9. $en_fecha = $db->querySingle("SELECT ESTA_EN_PERIODO(NOW()::DATE, :periodo_id)", [':periodo_id' => $user->periodo_id])['esta_en_periodo'];
  10. $periodo_fin = $db->querySingle("SELECT periodo_fecha_fin FROM periodo WHERE periodo_id = :periodo_id", [':periodo_id' => $user->periodo_id])['periodo_fecha_fin'];
  11. ?>
  12. <!DOCTYPE html>
  13. <html lang="en">
  14. <head>
  15. <title>Consultar horario | <?= $user->facultad['facultad'] ?? 'General' ?></title>
  16. <meta charset="utf-8">
  17. <meta http-equiv="content-type" content="text/plain; charset=UTF-8" />
  18. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  19. <?php include_once "import/html_css_files.php"; ?>
  20. <link rel="stylesheet" href="css/jquery-ui.css">
  21. <link rel="stylesheet" href="css/richtext.css" type="text/css">
  22. <link rel="stylesheet" href="css/clockpicker.css">
  23. <link rel="stylesheet" href="css/calendar.css">
  24. <link rel="stylesheet" href="css/fa_all.css" type="text/css">
  25. <script src="js/scrollables.js" defer></script>
  26. <script>
  27. const write = <?= $write ? 'true' : 'false' ?>;
  28. </script>
  29. <script src="js/moment.js" defer></script>
  30. </head>
  31. <!-- -->
  32. <body style="display: block;">
  33. <?php
  34. include('include/constantes.php');
  35. include("import/html_header.php");
  36. html_header("Consultar horario", "Sistema de gestión de checador");
  37. ?>
  38. <?= "<!-- $user -->" ?>
  39. <main class="container content marco content-margin" id="local-app">
  40. <section id="message"></section>
  41. <?php require('import/periodo.php') ?>
  42. <!-- Botón para abrir el modal -->
  43. <span class="d-inline-block" tabindex="0" data-toggle="tooltip" <?php if (!$en_fecha) : ?> title="No se puede crear una reposición fuera de la fecha de reposición" <?php endif; ?>>
  44. <button type="button" class="btn btn-primary" data-toggle="modal" <?php if ($en_fecha) : ?>data-target="#crearReposición" <?php else : ?>disabled style="pointer-events: none;" <?php endif; ?>>
  45. Crear Reposición
  46. </button>
  47. </span>
  48. <!-- Modal del formulario -->
  49. <div class="modal fade" id="crearReposición" tabindex="-1" role="dialog" aria-labelledby="crearReposiciónLabel" aria-hidden="true">
  50. <div class="modal-dialog modal-xl" role="document">
  51. <div class="modal-content">
  52. <div class="modal-header">
  53. <h5 class="modal-title" id="crearReposiciónLabel">Crear Reposición</h5>
  54. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  55. <span aria-hidden="true">&times;</span>
  56. </button>
  57. </div>
  58. <div class="modal-body">
  59. <form id="form" class="form-horizontal">
  60. <div class="form-group step" id="step-1">
  61. <div class="form-box">
  62. <div class="form-group row">
  63. <label for="clave_profesor" class="col-4 col-form-label">Profesor</label>
  64. <div class="col-8">
  65. <input list="lista_profesores" name="clave_profesor" id="clave_profesor" class="form-control" placeholder="Profesor" required="required">
  66. <div class="valid-feedback">
  67. Profesor encontrado
  68. </div>
  69. <div class="invalid-feedback">
  70. Profesor no encontrado
  71. </div>
  72. <datalist id="lista_profesores">
  73. <?php
  74. $profesores = $db->query('SELECT * FROM fs_profesor A WHERE facultad_id = :facultad_id AND EXISTS (
  75. SELECT * FROM horario join HORARIO_PROFESOR ON horario.HORARIO_ID = HORARIO_PROFESOR.horario_id WHERE HORARIO_PROFESOR.profesor_id = A.id AND HORARIO.periodo_id = :periodo_id
  76. ) ORDER BY grado, nombre', [':facultad_id' => $user->facultad['facultad_id'], ':periodo_id' => $user->periodo_id]);
  77. foreach ($profesores as $profesor) {
  78. extract($profesor);
  79. ?>
  80. <option data-grado="<?= $grado ?>" data-clave="<?= $clave ?>" data-profesor="<?= $profesor ?>" data-id="<?= $id; ?>" value="<?= "$clave | $grado $profesor" ?>"></option>
  81. <?php
  82. }
  83. ?>
  84. </datalist>
  85. <ul class="list-group" id="profesores"></ul>
  86. <input type="hidden" id="periodo_id" name="periodo_id" value="<?= $user->periodo_id ?>">
  87. <input type="hidden" id="profesor_id" name="profesor_id" value="">
  88. </div>
  89. </div>
  90. </div>
  91. </div>
  92. <div class="form-group step" id="step-2">
  93. <div class="form-box">
  94. <div class="form-group row">
  95. <label for="horario_reponer" class="col-4 col-form-label">Horario a reponer</label>
  96. <div class="col-8">
  97. <select name="horario_reponer" id="horario_reponer" class="form-control" required="required">
  98. </select>
  99. </div>
  100. </div>
  101. </div>
  102. <input type="hidden" name="horario_id" id="horario_id">
  103. </div>
  104. <div class="form-group step" id="step-3">
  105. <div class="form-box">
  106. <div class="form-group row">
  107. <label for="fechas_clase" class="col-4 col-form-label">Fecha de clase</label>
  108. <div class="col-8">
  109. <select name="fechas_clase" id="fechas_clase" class="form-control" required="required">
  110. </select>
  111. </div>
  112. </div>
  113. </div>
  114. </div>
  115. <div class="form-group step" id="step-4">
  116. <div class="form-box">
  117. <div class="form-group row">
  118. <label for="fecha_reponer" class="col-4 col-form-label">Fecha de reposición</label>
  119. <div class="col-6">
  120. <input type="text" placeholder="dd/mm/aaaa" name="fecha_reponer" id="fecha_reponer" class="form-control date-picker" required="required">
  121. </div>
  122. </div>
  123. <div class="form-group row">
  124. <label for="hora" class="col-4 col-form-label">Hora</label>
  125. <div class="col-3">
  126. <div id="hora" class="datalist datalist-select mb-1">
  127. <div class="datalist-input text-center">hh</div>
  128. <span class="ing-buscar icono"></span>
  129. <ul style="display:none">
  130. <?php foreach (range(7, 21) as $hora) { ?>
  131. <li data-id='<?= $hora ?>'><?= str_pad($hora, 2, "0", STR_PAD_LEFT) ?></li>
  132. <?php } ?>
  133. </ul>
  134. <input type="hidden" id="hora_reponer" name="horas" value="">
  135. </div>
  136. </div>
  137. <div class="col-3">
  138. <div id="minutos" class="datalist datalist-select mb-1">
  139. <div class="datalist-input text-center">mm</div>
  140. <span class="ing-buscar icono"></span>
  141. <ul style="display:none">
  142. <?php foreach (range(0, 45, 15) as $minuto) { ?>
  143. <li data-id='<?= $minuto ?>'><?= str_pad($minuto, 2, "0", STR_PAD_LEFT) ?></li>
  144. <?php } ?>
  145. </ul>
  146. <input type="hidden" id="minutos_reponer" name="minutos" value="">
  147. </div>
  148. </div>
  149. </div>
  150. </div>
  151. </div>
  152. <div class="form-group step" id="step-5">
  153. <div class="form-box">
  154. <div class="form-group row">
  155. <label for="descripcion_reposicion" class="col-4 col-form-label">Comentarios</label>
  156. <div class="col-6">
  157. <textarea name="descripcion_reposicion" id="descripcion_reposicion" rows="4" required="required" placeholder="Se requiere proyector, etc." maxlength="255" class="form-control"></textarea>
  158. </div>
  159. </div>
  160. <div class="form-group row align-items-center">
  161. <label class="col-4 col-form-label" for="sala">¿En sala de cómputo?</label>
  162. <div class="col-6">
  163. <div class="custom-control custom-switch">
  164. <input type="checkbox" class="custom-control-input" id="sala">
  165. <label class="custom-control-label" for="sala"></label>
  166. </div>
  167. </div>
  168. </div>
  169. </div>
  170. </div>
  171. </form>
  172. </div>
  173. <div class="modal-footer justify-content-center">
  174. <button class="btn btn-secondary" type="button" id="prev-button">Anterior</button>
  175. <button class="btn btn-secondary" type="button" id="next-button" disabled data-toggle="modal" data-target="#confirmationModal">Proponer reposición</button>
  176. </div>
  177. <!-- Modal confirmación -->
  178. <div class="modal fade" id="confirmationModal" tabindex="-1" role="dialog" aria-labelledby="confirmationModalLabel" aria-hidden="true">
  179. <div class="modal-dialog modal-sm" role="document">
  180. <div class="modal-content">
  181. <div class="modal-header">
  182. <h5 class="modal-title" id="confirmationModalLabel">Confirmación</h5>
  183. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  184. <span aria-hidden="true">&times;</span>
  185. </button>
  186. </div>
  187. <div class="modal-body">
  188. <p>¿Estás seguro de que deseas proponer la reposición?</p>
  189. <small>Recuerda que la aprobará tu jefe de carrera.</small>
  190. </div>
  191. <div class="modal-footer">
  192. <button type="button" class="btn btn-info" onclick="$('#confirmationModal').modal('hide');">Cancelar</button>
  193. <button type="button" class="btn btn-primary" data-dismiss="modal">Aceptar</button>
  194. </div>
  195. </div>
  196. </div>
  197. </div>
  198. </div>
  199. </div>
  200. </div>
  201. </main>
  202. </body>
  203. <script src="js/jquery.min.js"></script>
  204. <script src="js/bootstrap/popper.min.js"></script>
  205. <script src="js/bootstrap/bootstrap.min.js"></script>
  206. <script src="js/richtext.js"></script>
  207. <script src="js/clockpicker.js"></script>
  208. <script src="js/jquery-ui.js"></script>
  209. <script src="js/datepicker-es.js"></script>
  210. <script>
  211. $(document).ready(function() {
  212. $('.richtext').richText({
  213. fontList: ['indivisa-text', 'Arial'],
  214. imageUpload: true,
  215. placeholder: 'Escribe aquí la información de la reposición: necesito un proyector, etc.',
  216. });
  217. });
  218. $(".date-picker").datepicker($.datepicker.regional.es);
  219. $(".date-picker").datepicker({
  220. dateFormat: "dd/mm/yyyy",
  221. changeMonth: true,
  222. beforeShowDay: function(date) {
  223. // Disable Sundays (0 represents Sunday)
  224. return [date.getDay() != 0, ''];
  225. // Disable 2020-05-01
  226. }
  227. });
  228. // the minimum is today + 3 laboral days
  229. function getNextWorkingDay(date) {
  230. const day = date.getDay(); // Get the day of the week (0-6, where 0 is Sunday)
  231. // Check if it's Saturday (6), if so, add 2 days
  232. if (day === 6) {
  233. date.setDate(date.getDate() + 2);
  234. }
  235. // Add 1 day to skip to the next day
  236. date.setDate(date.getDate() + 1);
  237. // Check if it's a Sunday (0), if so, add 1 day
  238. if (date.getDay() === 0) {
  239. date.setDate(date.getDate() + 1);
  240. }
  241. // Add laboral days
  242. let laboralDaysCount = 1; // Start with 1 to account for the current day
  243. while (laboralDaysCount < 3) {
  244. date.setDate(date.getDate() + 1); // Add a day
  245. if (date.getDay() !== 6) { // Skip Saturdays
  246. laboralDaysCount++;
  247. }
  248. }
  249. return date;
  250. }
  251. $(".date-picker").datepicker("option", "minDate", getNextWorkingDay(new Date()));
  252. // the maximum is periodo_fin
  253. $(".date-picker").datepicker("option", "maxDate", new Date("<?= $periodo_fin ?>T03:24:00"));
  254. $(function() {
  255. $('[data-toggle="tooltip"]').tooltip()
  256. })
  257. </script>
  258. <script src="js/messages.js"></script>
  259. <script type="module" src="js/reposiciones.js"></script>
  260. </html>