mihorario.php 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681
  1. <?php
  2. require_once("../include/constantes.php");
  3. require_once("../include/util.php");
  4. require_once("../include/bd_pdo.php");
  5. require_once("../classes/ValidaSesion.php");
  6. require_once("../classes/MainMenu.php");
  7. $menu = 2;
  8. $submenu = 20;
  9. $stmt = $pdo->prepare('Select * from fs_periodo(:id, NULL, NULL, NULL)');
  10. $stmt->bindParam(":id", $_SESSION["periodo_id"]);
  11. if(!$stmt->execute()){
  12. //print_r($stmt->errorInfo());
  13. header("Location: ../index.php?error=2");
  14. exit();
  15. }
  16. $periodo_rs = $stmt->fetch();//Devuelve sólo 1 resultado
  17. $stmt->closeCursor(); // cierra conexion de resultado
  18. $stmt = null; // cierra conexion
  19. //--- Objeto para validar usuario. El id de usuario lo lee desde sesión
  20. $objSesion = new ValidaSesion($pdo, $submenu, APSA);
  21. if(!$objSesion->tieneAcceso()){
  22. $objSesion->terminaSesion();
  23. }
  24. if(!$objSesion->puedeEditar()){
  25. $errorDesc = "No puedes editar el horario.";
  26. }
  27. if(!$_SESSION["administrativo"]){
  28. header("Location: perfil.php");
  29. exit();
  30. }
  31. //$fecha_ini = date("Y-m-d");
  32. $fecha_ini = $periodo_rs["Periodo_fecha_inicial"];
  33. if(isset($_POST["filter_fecha"])){
  34. $fecha_ini = $_POST["filter_fecha"];
  35. }
  36. //Dias
  37. $stmt = $pdo->prepare('Select * from fs_dia(NULL)');
  38. if(!$stmt->execute()){
  39. $errorDesc = "Error al obtener los días";
  40. print_r($stmt->errorInfo());
  41. }else
  42. $dias_rs = $stmt->fetchAll();
  43. $stmt->closeCursor();
  44. // Tipos de horario
  45. $stmt = $pdo->prepare('Select * from fs_tipohorario(NULL, true)');
  46. if(!$stmt->execute()){
  47. $errorDesc = "Error al obtener los tipos de horario";
  48. print_r($stmt->errorInfo());
  49. }else
  50. $tipohorario_rs = $stmt->fetchAll();
  51. $stmt->closeCursor();
  52. //Estado de horario (edicion/nuevo)
  53. $stmt = $pdo->prepare('Select * from fs_mihorarioestado(:usr)');
  54. $stmt->bindParam(":usr", $_SESSION["usuario_id"]);
  55. if(!$stmt->execute()){
  56. $errorDesc = "Error al cargar el horario";
  57. print_r($stmt->errorInfo());
  58. }else{
  59. $rs = $stmt->fetch();
  60. $horario_estado = $rs["fs_mihorarioestado"];
  61. unset($rs);
  62. }
  63. $stmt->closeCursor();
  64. $stmt = null;
  65. function enBloqueClase($pdo, $hora, $frac, $nivel){
  66. $stmt = $pdo->prepare('Select * from fs_horaclase(:nivel, NULL)');
  67. $stmt->bindParam(":nivel", $nivel);
  68. $stmt->execute();
  69. $bloque_rs = $stmt->fetchAll();
  70. $horaFracc = $hora .":". (60/FRACCION_HORA*$frac).":00";
  71. foreach($bloque_rs as $bloque){
  72. if(strtotime($horaFracc) >= strtotime($bloque["HoraClase_inicio"]) && strtotime($horaFracc) < strtotime($bloque["HoraClase_final"]))
  73. return "fraccion-sugerida";
  74. }
  75. return "";
  76. }
  77. function validaHorarios(& $arr){
  78. $erroresArr = array();
  79. for($i = 0; $i < count($arr)-1; $i++){
  80. for($j = $i+1; $j < count($arr); $j++){
  81. if($arr[$i]["Dia_id"] == $arr[$j]["Dia_id"] && !($arr[$i]["TipoHorario_id"] == 3 && $arr[$i]["TipoHorario_id"] == $arr[$j]["TipoHorario_id"])){
  82. if( (date('H:i', strtotime($arr[$i]["Hora_inicio"])) <= date('H:i', strtotime($arr[$j]["Hora_inicio"])) && date('H:i', strtotime($arr[$i]["Hora_final"])) > date('H:i', strtotime($arr[$j]["Hora_inicio"])) )
  83. || (date('H:i', strtotime($arr[$j]["Hora_inicio"])) <= date('H:i', strtotime($arr[$i]["Hora_inicio"])) && date('H:i', strtotime($arr[$j]["Hora_final"])) > date('H:i', strtotime($arr[$i]["Hora_inicio"])) )
  84. ){
  85. if($arr[$i]["TipoHorario_id"] < $arr[$j]["TipoHorario_id"]){
  86. $erroresArr[] = array('nombre'=>$arr[$i]["TipoHorario_desc"], 'dia'=> diaNombre($arr[$i]["Dia_id"]), 'hora_i'=>date('H:i', strtotime($arr[$i]["Hora_inicio"])), 'hora_f'=> date('H:i', strtotime($arr[$i]["Hora_final"])));
  87. $arr[$i]["Duracion"] = (strtotime('2019-01-01 '.$arr[$j]["Hora_inicio"]) - strtotime('2019-01-01 '.$arr[$i]["Hora_inicio"]))/60;
  88. if($arr[$i]["Duracion"] <= 0) array_splice($arr, $i, 1);
  89. }else{ //if($arr[$i]["TipoHorario_id"] < $arr[$j]["TipoHorario_id"])
  90. $erroresArr[] = array('nombre'=>$arr[$i]["TipoHorario_desc"], 'dia'=> diaNombre($arr[$i]["Dia_id"]), 'hora_i'=>date('H:i', strtotime($arr[$i]["Hora_inicio"])), 'hora_f'=> date('H:i', strtotime($arr[$i]["Hora_final"])));
  91. $arr[$j]["Duracion"] = (strtotime('2019-01-01 '.$arr[$i]["Hora_inicio"]) - strtotime('2019-01-01 '.$arr[$j]["Hora_inicio"]))/60;
  92. if($arr[$j]["Duracion"] <= 0) array_splice($arr, $j, 1);
  93. }
  94. }
  95. }
  96. }
  97. }
  98. return $erroresArr;
  99. }
  100. ?>
  101. <!DOCTYPE html>
  102. <html lang="es" prefix="og: http://ogp.me/ns#">
  103. <head>
  104. <title>APSA - Facultad de Ingeniería</title>
  105. <meta charset="utf-8">
  106. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  107. <link rel="icon" type="image/png" href="../img/favicon.png" />
  108. <link rel="stylesheet" href="../css/bootstrap-ulsa.min.css" type="text/css">
  109. <link rel="stylesheet" href="../css/indivisa.css" type="text/css">
  110. <link rel="stylesheet" href="../css/sgi.css?rand=<?php echo rand();?>" type="text/css">
  111. <link rel="stylesheet" href="../css/fa_all.css" type="text/css">
  112. <link rel="stylesheet" href="../css/jquery-ui.css" type="text/css">
  113. <link rel="stylesheet" href="../css/calendar.css" type="text/css">
  114. <link rel="stylesheet" href="./css/horario.css" type="text/css">
  115. </head>
  116. <body>
  117. <div>
  118. <?php
  119. //--- Objeto que pinta menu
  120. $menuObj = new MainMenu($_SESSION["usuario_id"], $menu, $pdo, APSA, "Mi horario");//usr, menu, pdo, sist
  121. $menuObj->printMenu();
  122. //--Manejo de errores y mensajes de exito
  123. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  124. switch ($_GET["error"]){
  125. case 0: $errorDesc = "No se reciberon los datos del horario."; break;
  126. case 1: $errorDesc = "Ocurrió un error al insertar los datos del horario."; break;
  127. case 2: $errorDesc = "Ocurrió un error al actualizar los datos del horario."; break;
  128. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  129. case 4: $errorDesc = "Ocurrió un error al cancelar el horario."; break;
  130. case 5: $errorDesc = "Hay horarios con conflicto que se borraron al realizar el envío."; break;
  131. }
  132. }
  133. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  134. switch ($_GET["ok"]){
  135. case 0: $successDesc = "El estado del envío del horario se guardó correctamente."; break;
  136. case 1: $successDesc = "El horario se canceló correctamente."; break;
  137. }
  138. }
  139. ?>
  140. <div class="container-fluid marco">
  141. <div class="row mt-3">
  142. <div class="col-12 text-right">
  143. <a href="perfil.php" class="btn btn-outline-danger"><?php echo $ICO["cancelar"];?> Regresar</a>
  144. </div>
  145. </div>
  146. <?php include_once("../include/errorMessage.php"); ?>
  147. <form action="" method="post">
  148. <div class="form-box form-box-info">
  149. <div class="form-group row">
  150. <label for="filter_fecha" class="col-4 col-form-label">Fecha del horario *</label>
  151. <div class="col-8 col-sm-4">
  152. <input id="filter_fecha" name="filter_fecha" type="text" class="form-control date-picker" placeholder="dd/mm/aaaa" maxlength="10" required="required" readonly="readonly" value="<?php echo fechaSlash($fecha_ini);?>">
  153. </div>
  154. </div>
  155. </div>
  156. <div class="form-group row">
  157. <div class="col-12 text-center">
  158. <button type="submit" class="btn btn-outline-primary btn-fecha"><?php echo $ICO["calendario"];?> Actualizar horario a esta fecha</button>
  159. </div>
  160. </div>
  161. </form>
  162. <p class="mb-5"><a href="./files/horario.xlsx" class="btn btn-outline-secondary btn-sm" download="horario.xlsx" target="_blank"><?php echo $ICO["descargar"];?> Descargar plantilla de horario</a></p>
  163. </div>
  164. <?php
  165. /* Definidas en constantes.php
  166. HORA_INICIO = 7;
  167. HORA_FINAL = 22;
  168. FRACCION_HORA = 4;*/
  169. if(isset($horario_estado) && isset($tipohorario_rs) && isset($dias_rs)){
  170. if($_SESSION["profesor"] && !isset($_SESSION["periodo_id"]) || $_SESSION["periodo_id"] ==""){
  171. echo "<p>Necesitas seleccionar un periodo.</p>";
  172. exit();
  173. }
  174. ?>
  175. <main class="container-fluid content marco-wide">
  176. <ul class="nav nav-tabs" id="myTab" role="tablist">
  177. <li class="nav-item">
  178. <a class="nav-link active" id="tab2-tab" data-toggle="tab" href="#tab2" role="tab" aria-controls="lista" aria-selected="false">Horario aprobado</a>
  179. </li>
  180. <li class="nav-item">
  181. <a class="nav-link" id="tab1-tab" data-toggle="tab" href="#tab1" role="tab" aria-controls="calendario" aria-selected="true">Horario propuesto</a>
  182. </li>
  183. </ul>
  184. <div class="tab-content" id="horariosTabContent">
  185. <div class="tab-pane fade show active pt-2" id="tab2" role="tabpanel" aria-labelledby="tab2-tab">
  186. <?php
  187. //Obtiene horario del usuario
  188. /*if($_SESSION["profesor"]){
  189. $stmt = $pdo->prepare('Select * from fs_mihorario(:usr, :per, 3)');//Obtiene todo el calendario
  190. $stmt->bindParam(":per", $_SESSION["periodo_id"]);
  191. }else
  192. $stmt = $pdo->prepare('Select * from fs_mihorario(:usr, 0, 3)');//Obtiene todo el calendario
  193. $stmt->bindParam(":usr", $_SESSION["usuario_id"]);*/
  194. $stmt = $pdo->prepare('Select * from fs_mihorariofull(:usr, :fecha, 3)');//Obtiene todo el calendario
  195. $stmt->bindParam(":fecha", $fecha_ini);
  196. $stmt->bindParam(":usr", $_SESSION["usuario_id"]);
  197. if(!$stmt->execute()){
  198. //$t = $stmt->errorInfo();
  199. echo "Ocurrió un error al obtener el horario";
  200. }else
  201. $horario_rs = $stmt->fetchAll();
  202. if(isset($horario_rs) && count($horario_rs) > 0){
  203. $horaMin = horaMin($horario_rs, "Hora_inicio");
  204. $horaMax = horaMax($horario_rs, "Hora_final");
  205. $stmt->closeCursor();
  206. $rs_i = 0;
  207. $spacerArr = array(1=>0,0,0,0,0,0);
  208. $total_tipo = array(1=>0,0,0);
  209. $erroresArr = validaHorarios($horario_rs);
  210. if(count($erroresArr) > 0){
  211. foreach($erroresArr as $err){
  212. echo '<h4 class="text-danger my-4">'.$ICO["alerta"].' El horario administrativo actual se sobrepone con el bloque <b>'.$err['nombre'].' ( '.$err['dia'].' '.$err['hora_i'].' - '.$err['hora_f'].' )</b> y no se puede mostrar correctamente.</h4>';
  213. }
  214. echo '<p>Crea un horario administrativo nuevo o cancela el actual.</p>';
  215. }else{
  216. ?>
  217. <div class="row justify-content-md-center mb-2">
  218. <div class="col-12 col-md-8 mt-4">
  219. <form action="./export/pdf_horarioadministrativo.php" onsubmit="abrePdf()" target="_blank" method="post" class="form-inline">
  220. <input type="hidden" name="fecha" id="fecha_pdf">
  221. <input type="hidden" name="self" value="1">
  222. <?php
  223. $stmt = $pdo->prepare('Select * from fs_director()');
  224. if(!$stmt->execute()){
  225. $return["error"] .= "Ocurrió un error al obtener datos del director.";
  226. $error = true;
  227. }
  228. $director_rs = $stmt->fetch();
  229. $stmt->closeCursor();
  230. if($director_rs["Usuario_id"] != $_SESSION["usuario_id"]){
  231. ?>
  232. <label for="superior" class="mx-2">Superior</label>
  233. <select name="sup" id="superior" class="form-control mx-2">
  234. <?php
  235. $stmt = $pdo->prepare('Select * from fs_superiorusuario(:usr, NULL)');//Obtiene posibles superiores
  236. $stmt->bindParam(":usr", $_SESSION["usuario_id"]);
  237. if(!$stmt->execute()){
  238. //$t = $stmt->errorInfo();
  239. echo "Ocurrió un error al obtener el superior";
  240. }else{
  241. $sup_rs = $stmt->fetchAll();
  242. foreach($sup_rs as $sup){
  243. ?>
  244. <option value="<?php echo $sup["Usuario_id"];?>"><?php echo $sup["Usuario_apellidos"]." ".$sup["Usuario_nombre"];?></option>
  245. <?php }
  246. }?>
  247. </select>
  248. <?php } ?>
  249. <button type="submit" class="btn btn-outline-primary"><?php echo $ICO["descargar"];?> Generar pdf</button>
  250. <input type="hidden" name="id" value="<?php echo $_SESSION["usuario_id"];?>">
  251. <input type="hidden" name="tipo" value="3">
  252. </form>
  253. </div>
  254. <div class="col-12 col-md-4 mt-4">
  255. <button type="button" class="btn btn-outline-danger" data-toggle="modal" data-target="#modal_aprobado"><?php echo $ICO["cancelar"];?> Cancelar horario</button>
  256. </div>
  257. </div>
  258. <?php }//fn sin errores ?>
  259. <div class="row justify-content-md-center">
  260. <div class="col-12 col-md-10 mt-2">
  261. <?php
  262. $xtpl = new XTemplate('./tpl/mihorario_reporte.tpl.html');
  263. foreach($dias_rs as $dia){
  264. $xtpl->assign("DIA", $dia["Dia_desc"]);
  265. $xtpl->parse("main.header");
  266. }
  267. //$horas_dif = intval(date('H', strtotime($horaMax))) - intval(date('H', strtotime($horaMin)));
  268. for($h = date('H', strtotime($horaMin)); $h <= date('H', strtotime($horaMax)) && $h < HORA_FINAL; $h++){
  269. $xtpl->assign("HORA", date('H', strtotime($h.":00")));
  270. $xtpl->assign("FRACCIONES", FRACCION_HORA);
  271. $xtpl->parse("main.hora_row.hora");
  272. for($f = 0; $f < FRACCION_HORA; $f++){
  273. foreach($dias_rs as $dia){
  274. if($rs_i < count($horario_rs) && date('H:i', strtotime($horario_rs[$rs_i]["Hora_inicio"])) == date('H:i', strtotime($h.":".($f * (60/FRACCION_HORA)))) && $horario_rs[$rs_i]["Dia_id"] == $dia["Dia_id"]){
  275. $size = $horario_rs[$rs_i]["Duracion"]/(60/FRACCION_HORA);
  276. $spacerArr[$dia["Dia_id"]] = $size -1;
  277. $xtpl->assign("DURACION_SIZE", $size);
  278. $xtpl->assign("COLOR", $horario_rs[$rs_i]["TipoHorario_color"]);
  279. $xtpl->assign("TIPO", $horario_rs[$rs_i]["TipoHorario_desc"]);
  280. $total_tipo[$horario_rs[$rs_i]["TipoHorario_id"]]+= $horario_rs[$rs_i]["Duracion"]/60;
  281. $salon = "";
  282. do{
  283. if($horario_rs[$rs_i]["Salon_desc"] != "") $salon = "Salón: ".$horario_rs[$rs_i]["Salon_desc"];
  284. else if($horario_rs[$rs_i]["Materia_desc"] != "") $salon = "<em>Pendiente</em>";
  285. $xtpl->assign("MATERIA", $horario_rs[$rs_i]["Materia_desc"]);
  286. $grupo = "";
  287. //if($_SESSION["nivel_id"] == 1)
  288. $grupo = $horario_rs[$rs_i]["Grupo_desc"]." ".$horario_rs[$rs_i]["Carrera_prefijo"];
  289. //else
  290. //$grupo = $horario_rs[$rs_i]["Grupo_desc"];
  291. $xtpl->assign("GRUPO", $grupo);
  292. if($horario_rs[$rs_i]["Materia_desc"] != "")
  293. $xtpl->parse("main.hora_row.td.td_mihorario.texto");
  294. $rs_i++;
  295. }while($rs_i < count($horario_rs) && date('H:i', strtotime($horario_rs[$rs_i-1]["Hora_inicio"])) == date('H:i', strtotime($horario_rs[$rs_i]["Hora_inicio"])) && $horario_rs[$rs_i]["Dia_id"] == $dia["Dia_id"]);
  296. $xtpl->assign("SALON", $salon);
  297. $min = $f*(60/FRACCION_HORA);
  298. if($min < 10) $min = "0".$min;
  299. $xtpl->assign("MIN", $min);
  300. $xtpl->parse("main.hora_row.td.td_mihorario");
  301. }else{
  302. if(!isset($spacerArr[$dia["Dia_id"]]) || $spacerArr[$dia["Dia_id"]] == 0)
  303. $xtpl->parse("main.hora_row.td.td_vacio");
  304. else
  305. $spacerArr[$dia["Dia_id"]]--;
  306. }
  307. $xtpl->parse("main.hora_row.td");
  308. }
  309. $xtpl->parse("main.hora_row");
  310. }
  311. }
  312. $xtpl->parse("main");
  313. $stmt = $pdo->prepare('Select * from fs_tipohorario(NULL, NULL)');
  314. $stmt->execute();
  315. $tipohorarioAll_rs = $stmt->fetchAll();
  316. $stmt->closeCursor();
  317. if(count($tipohorarioAll_rs)>0){
  318. ?>
  319. <div class="row justify-content-md-center mb-2">
  320. <div class="col-12 col-md-10">
  321. <?php foreach($tipohorarioAll_rs as $tipo){ ?>
  322. <span class="tipo-area"><span style="color:<?php echo $tipo["TipoHorario_color"]?>"><?php echo $ICO_LG["circulo"];?></span> <b><?php echo $tipo["TipoHorario_desc"]?></b> [<?php echo $total_tipo[$tipo["TipoHorario_id"]]?> hrs]</span>
  323. <?php } ?>
  324. <span class="tipo-area"><b>TOTAL</b> [<?php echo $total_tipo[1]+$total_tipo[2]+$total_tipo[3]?> hrs]</span>
  325. </div>
  326. </div>
  327. <?php }
  328. $xtpl->out("main");
  329. ?>
  330. </div>
  331. </div>
  332. <?php
  333. }else{
  334. echo "<h3 class='text-center mt-2'>No hay horarios aprobados</h3>";
  335. }?>
  336. </div><!-- fin tab aprobado -->
  337. <div class="tab-pane fade" id="tab1" role="tabpanel" aria-labelledby="tab1-tab">
  338. <!-- Referencia de colores -->
  339. <form action="mihorario.php" method="post">
  340. <input type="hidden" name="grupo" value="<?php echo $filter_grupo?>">
  341. <div class="mt-2 mb-2">
  342. <div class="row mb-2">
  343. <?php if($horario_estado == 1){ ?>
  344. <div class="col-8">
  345. <p><em>Haz clic en el calendario para asignar un bloque de horario.<br>Puedes expandir los horarios arrastrando desde la base inferior.</em></p>
  346. </div>
  347. <div class="col-4 text-center"><button type="button" class="btn btn-outline-primary" data-toggle="modal" data-target="#modal_send"><?php echo $ICO["aceptar"];?> Enviar para aprobación</button></div>
  348. <?php }else{ ?>
  349. <div class="col-8">
  350. <p><b>El horario está en espera de aprobación</b></p>
  351. </div>
  352. <div class="col-4 text-right"><button type="button" class="btn btn-outline-danger" data-toggle="modal" data-target="#modal_send"><?php echo $ICO["cancelar"];?> Cancelar envío de aprobación</button></div>
  353. <?php } ?>
  354. </div>
  355. <div class="row">
  356. <div class="col-12 mb-4 text-right">
  357. <button type="button" class="btn btn-outline-danger" aria-hidden="true" data-toggle="modal" data-target="#modal_confirm_all"><?php echo $ICO["borrar"];?> Borrar horario administrativo</button>
  358. </div>
  359. </div>
  360. <?php
  361. $stmt = $pdo->prepare('Select * from fs_tipohorario(NULL, NULL)');
  362. $stmt->execute();
  363. $tipohorarioAll_rs = $stmt->fetchAll();
  364. $stmt->closeCursor();
  365. if(count($tipohorarioAll_rs)>0){
  366. ?>
  367. <div class="row justify-content-md-center mb-3">
  368. <div class="col-12 col-md-10">
  369. <?php foreach($tipohorarioAll_rs as $tipo){ ?>
  370. <span class="tipo-area"><span style="color:<?php echo $tipo["TipoHorario_color"]?>"><?php echo $ICO_LG["circulo"];?></span> <b><?php echo $tipo["TipoHorario_desc"]?></b> [<span id="total_tipo_<?php echo $tipo["TipoHorario_id"]?>">0</span> hrs]</span>
  371. <?php } ?>
  372. <span class="tipo-area"><b>TOTAL</b> [<span id="total_all">0</span> hrs]</span>
  373. </div>
  374. </div>
  375. <?php } ?>
  376. <div class="row justify-content-md-center">
  377. <div class="col-md-auto">
  378. <table class="table table-sm table-responsive table-borderless table-striped calendario" id="tabla-horario" data-hora-inicio="<?php echo HORA_INICIO;?>" data-fracciones = "<?php echo FRACCION_HORA; ?>">
  379. <thead class="thead-dark">
  380. <tr>
  381. <th>Hora</th>
  382. <?php foreach($dias_rs as $dia){
  383. echo "<th data='dia_".$dia["Dia_id"]."'>".$dia["Dia_desc"]."</th>";
  384. } ?>
  385. </tr>
  386. </thead>
  387. <tbody id="calendario-body">
  388. <tr>
  389. <td class="text-right font-weight-bold">Total &nbsp;</td>
  390. <?php foreach($dias_rs as $dia){
  391. echo "<td class='text-center table-dark'><span id='total_".$dia["Dia_id"]."'>0</span> hrs</td>";
  392. } ?>
  393. </tr>
  394. <?php
  395. $biccell = false;
  396. for($h = HORA_INICIO, $i=0; $h < HORA_FINAL; $h++, $i++){?>
  397. <tr>
  398. <td data-hora="<?php echo $h;?>" data-index="<?php echo $i;?>" class="hora" ><?php echo $h;?>:00 </td>
  399. <?php
  400. if(!$biccell){
  401. $biccell = true;
  402. ?>
  403. <td colspan='<?php echo count($dias_rs); ?>' rowspan='<?php echo (HORA_FINAL-HORA_INICIO); ?>'>
  404. <div class="area-horario" id="area-horario">
  405. <table class="table table-borderless table-striped">
  406. <tbody>
  407. <?php
  408. for($h2 = HORA_INICIO; $h2 < HORA_FINAL; $h2++){
  409. for($f = 0; $f < FRACCION_HORA; $f++){
  410. echo "<tr class='dia'>";
  411. foreach($dias_rs as $dia){
  412. //echo "$h2, $f => ".enBloqueClase($h2, $f);
  413. $editable = "";
  414. if($horario_estado == 1) $editable = "editable";
  415. echo "<td title='".$h2.":".sprintf("%02d", ($f*(60/FRACCION_HORA)))."' data-dia='".$dia["Dia_id"]."' data-hora='".$h2."' data-fraccion='".($f*(60/FRACCION_HORA))."' class='fraccion ".$editable." ".enBloqueClase($pdo, $h2, $f, $_SESSION["nivel_id"])."'></td>";
  416. }
  417. echo "</tr>";
  418. }
  419. }
  420. ?>
  421. </tbody>
  422. </table>
  423. <div id="bloque-horarios"></div>
  424. </div>
  425. </td>
  426. <?php
  427. } ?>
  428. </tr>
  429. <?php } ?>
  430. </tbody>
  431. </table>
  432. </div>
  433. </div>
  434. </div>
  435. </form>
  436. </div><!-- fin tab propuesto -->
  437. </div>
  438. <?php }//existen vars ?>
  439. </main>
  440. <!--- FOOTER--->
  441. <?php require_once("../include/footer.php"); ?>
  442. <?php if(isset($horario_estado) && isset($tipohorario_rs) && isset($dias_rs)){ ?>
  443. <!-- Modal -->
  444. <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  445. <div class="modal-dialog modal-dialog-centered" role="document">
  446. <div class="modal-content">
  447. <div class="modal-header">
  448. <h4 class="col-12 modal-title text-center"><span id="modalLabel">Crear Horario</span>
  449. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  450. <span aria-hidden="true">&times;</span>
  451. </button></h4>
  452. </div>
  453. <div class="modal-body ">
  454. <form action="#" method="post" id="formaModal" onsubmit="return false"><!-- submitForm() -->
  455. <input type="hidden" name="id" id="id">
  456. <input type="hidden" name="id_db" id="id_db">
  457. <input type="hidden" name="dia" id="dia">
  458. <input type="hidden" name="hora" id="hora">
  459. <input type="hidden" name="fraccion" id="fraccion">
  460. <div class="form-box">
  461. <div class="row form-group">
  462. <label for="duracion" class="col-4 col-form-label">Día y hora</label>
  463. <div class="col-8 pt-2">
  464. <span id="fecha_horario"></span>
  465. </div>
  466. </div>
  467. <div class="row form-group">
  468. <label for="tipo" class="col-4 col-form-label">Tipo horario *</label>
  469. <div class="col-8">
  470. <select name="tipo" id="tipo" class="form-control" required="required">
  471. <?php
  472. foreach($tipohorario_rs as $tipo){ ?>
  473. <option value="<?php echo $tipo["TipoHorario_id"]; ?>" data-color="<?php echo $tipo["TipoHorario_color"]; ?>" ><?php echo $tipo["TipoHorario_desc"];?></option>
  474. <?php }?>
  475. </select>
  476. </div>
  477. </div>
  478. <div class="row form-group">
  479. <label for="duracion" class="col-4 col-form-label">Duración *</label>
  480. <div class="col-8">
  481. <select name="duracion" id="duracion" class="form-control" required="required">
  482. <?php
  483. for($h = 1; $h <=8 ; $h++){ ?>
  484. <option value="<?php echo $h; ?>"><?php echo $h;?> horas</option>
  485. <?php }?>
  486. </select>
  487. <div class="invalid-feedback">La duración tiene conflictos con el bloque siguiente o está fuera del horario permitido.</div>
  488. </div>
  489. </div>
  490. </div>
  491. <div class="form-group row">
  492. <div class="col-12 text-center">
  493. <button type="submit" class="btn btn-outline-primary" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  494. <button type="reset" class="btn btn-outline-danger" data-dismiss="modal"><?php echo $ICO["cancelar"];?> Cancelar</button>
  495. </div>
  496. </div>
  497. </form>
  498. </div>
  499. </div>
  500. </div>
  501. </div>
  502. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  503. <div class="modal-dialog modal-dialog-centered" role="document">
  504. <div class="modal-content">
  505. <div class="modal-body">
  506. <div class="row">
  507. <div class="col">
  508. <p class="font-weight-bold">¿Estás seguro de que quieres borrar el bloque de horario?</p>
  509. <p>Esta acción no se puede deshacer.</p>
  510. </div>
  511. </div>
  512. </div>
  513. <div class="modal-footer">
  514. <input type="hidden" id="id_borrar" value="">
  515. <button type="button" class="btn btn-outline-primary bloque-borra"><?php echo $ICO["aceptar"];?> Borrar</button>
  516. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  517. </div>
  518. </div>
  519. </div>
  520. </div>
  521. <div class="modal fade" id="modal_confirm_all" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  522. <div class="modal-dialog modal-dialog-centered" role="document">
  523. <div class="modal-content">
  524. <div class="modal-body">
  525. <div class="row">
  526. <div class="col">
  527. <p class="font-weight-bold">¿Estás seguro de que quieres borrar todos los bloques de horario?</p>
  528. <p>Esta acción no se puede deshacer. Los bloques de horario docente no se pueden borrar.</p>
  529. </div>
  530. </div>
  531. </div>
  532. <div class="modal-footer">
  533. <button type="button" class="btn btn-outline-primary borrar-todo"><?php echo $ICO["aceptar"];?> Borrar todo</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. <?php if($horario_estado == 1){ ?>
  540. <div class="modal fade" id="modal_send" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  541. <div class="modal-dialog modal-dialog-centered" role="document">
  542. <div class="modal-content">
  543. <div class="modal-body">
  544. <div class="row">
  545. <div class="col">
  546. <p class="font-weight-bold">¿Estás seguro de que quieres enviar el horario para su aprobación?</p>
  547. </div>
  548. </div>
  549. </div>
  550. <div class="modal-footer">
  551. <input type="hidden" id="id_borrar" value="">
  552. <button type="button" class="btn btn-outline-primary bloque-send" data-orig="1" data-dest="2"><?php echo $ICO["aceptar"];?> Enviar</button>
  553. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  554. </div>
  555. </div>
  556. </div>
  557. </div>
  558. <?php } else {?>
  559. <div class="modal fade" id="modal_send" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  560. <div class="modal-dialog modal-dialog-centered" role="document">
  561. <div class="modal-content">
  562. <div class="modal-body">
  563. <div class="row">
  564. <div class="col">
  565. <p class="font-weight-bold">¿Estás seguro de que quieres cancelar el envío de la aprobación del horario?</p>
  566. </div>
  567. </div>
  568. </div>
  569. <div class="modal-footer">
  570. <input type="hidden" id="id_borrar" value="">
  571. <button type="button" class="btn btn-outline-primary bloque-send" data-orig="2" data-dest="1"><?php echo $ICO["aceptar"];?> Cancelar envío</button>
  572. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Mantener envío</button>
  573. </div>
  574. </div>
  575. </div>
  576. </div>
  577. <?php }?>
  578. <div class="modal fade" id="modal_aprobado" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  579. <div class="modal-dialog modal-dialog-centered" role="document">
  580. <div class="modal-content">
  581. <div class="modal-body">
  582. <div class="row">
  583. <div class="col">
  584. <p class="font-weight-bold">¿Estás seguro de que quieres cancelar el horario aprobado?</p>
  585. <p>El horario regresará a estar pendiente de aprobación.</p>
  586. </div>
  587. </div>
  588. </div>
  589. <div class="modal-footer">
  590. <form action="./action/mihorario_cancela.php" method="post">
  591. <button type="submit" class="btn btn-outline-primary" data-orig="2" data-dest="1"><?php echo $ICO["aceptar"];?> Cancelar horario</button>
  592. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Mantener horario</button>
  593. </form>
  594. </div>
  595. </div>
  596. </div>
  597. </div>
  598. </div>
  599. <?php }//existen vars ?>
  600. <script src="../js/jquery.min.js"></script>
  601. <script src="../js/jquery-ui.js"></script>
  602. <script src="../js/datepicker-es.js"></script>
  603. <script src="../js/bootstrap/popper.min.js"></script>
  604. <script src="../js/bootstrap/bootstrap.min.js"></script>
  605. <script src="./js/horario.js"></script>
  606. <script src="./js/mihorario.js"></script>
  607. <script src="../js/sidebarmenu.js"></script>
  608. <script src="../js/util.js"></script>
  609. <script>
  610. var id_obj = 0;
  611. var horariosObj = [];
  612. var _reloadTime = 45; //en segundos
  613. var _w = 180, _h = 12;//tamaño de bloques
  614. var _frac = parseInt($('#tabla-horario').data('fracciones'));
  615. var _hora_min = parseInt($('#tabla-horario').data('hora-inicio'));
  616. var _horarioEstado = <?php echo $horario_estado;?>;
  617. function abrePdf(){
  618. $("#fecha_pdf").val($("#filter_fecha").val());
  619. }
  620. $(document).ready(function(){
  621. $(".date-picker" ).datepicker({ dateFormat: "dd/mm/yy" });
  622. $(".date-picker" ).datepicker( $.datepicker.regional[ "es" ] );
  623. });
  624. </script>
  625. </body>
  626. </html>