constancias_gema.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  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 = 30;
  8. $submenu = 302;
  9. //--- Objeto para validar usuario. El id de usuario lo lee desde sesión
  10. $objSesion = new ValidaSesion($pdo, $submenu, CONSTANCIA);
  11. if(!$objSesion->tieneAcceso()){
  12. $objSesion->terminaSesion();
  13. }
  14. $objSesion->validaPeriodoUsuario();//si no tiene periodo manda a main
  15. $stmt = $pdo->prepare('Select * from fs_insigniatipo(NULL, true)');
  16. if(!$stmt->execute()){
  17. $errorDesc = "Ocurrió un error al obtener las fechas del periodo";
  18. //print_r($stmt->errorInfo());
  19. }else{
  20. $tipo_rs = $stmt->fetchAll();
  21. }
  22. ?>
  23. <!DOCTYPE html>
  24. <html lang="es" prefix="og: http://ogp.me/ns#">
  25. <head>
  26. <title>Constancias - Facultad de Ingeniería</title>
  27. <meta charset="utf-8">
  28. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  29. <link rel="icon" type="image/png" href="../img/favicon.png" />
  30. <link rel="stylesheet" href="../css/bootstrap-ulsa.min.css" type="text/css">
  31. <link rel="stylesheet" href="../css/indivisa.css" type="text/css">
  32. <link rel="stylesheet" href="../css/sgi.css?rand=<?php echo rand();?>" type="text/css">
  33. <link rel="stylesheet" href="../css/fa_all.css" type="text/css">
  34. <link rel="stylesheet" href="../css/jquery-ui.css" type="text/css">
  35. <link rel="stylesheet" href="../css/calendar.css" type="text/css">
  36. </head>
  37. <body>
  38. <div>
  39. <?php
  40. //--- Objeto que pinta menu
  41. $menuObj = new MainMenu($_SESSION["usuario_id"], $menu, $pdo, CONSTANCIA, "Constancias de insignias");//usr, menu, pdo, sist
  42. $menuObj->printMenu();
  43. if($_SESSION["periodo_id"] != ""){
  44. $filter_periodo = $_SESSION["periodo_id"];
  45. //busca datos del periodo
  46. $stmt = $pdo->prepare('Select * from fs_periodo(:periodo, NULL, NULL, NULL)');
  47. $stmt->bindParam(":periodo", $filter_periodo);
  48. if(!$stmt->execute()){
  49. $errorDesc = "Ocurrió un error al obtener las fechas del periodo";
  50. //print_r($stmt->errorInfo());
  51. }else{
  52. $periodo_rs = $stmt->fetch();
  53. $query = ":periodo, ";
  54. if(isset($_POST["tipo"]) && $_POST["tipo"]!=""){
  55. $filter_tipo = filter_input(INPUT_POST, "tipo", FILTER_SANITIZE_NUMBER_INT);
  56. $query.= ":tipo, ";
  57. }else{
  58. $query.= "NULL, ";
  59. }
  60. $query .= "0, ".MAX_ROWS;
  61. $stmt = $pdo->prepare('Select * from fs_insigniatotal('.$query.')');// Cambiar por una que obtenga totales
  62. $stmt->bindParam(":periodo", $filter_periodo);
  63. if(isset($filter_tipo)) $stmt->bindParam(":tipo", $filter_tipo);
  64. if($stmt->execute()){
  65. $insignias_rs = $stmt->fetchAll();
  66. $stmt->closeCursor();
  67. }
  68. }
  69. }//hay periodo seleccionado
  70. else{
  71. $errorDesc = "Debes seleccionar un periodo.";
  72. }
  73. if(count($insignias_rs) == 0){
  74. $errorDesc = "No hay eventos disponibles.";
  75. }
  76. //--Manejo de errores y mensajes de exito
  77. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  78. switch ($_GET["error"]){
  79. case 0: $errorDesc = "No se reciberon los datos para generar el documento."; break;
  80. case 1: $errorDesc = "No tienes permisos de realizar esa acción."; break;
  81. case 2: $errorDesc = "Ocurrió un error al obtener los datos de las constancias."; break;
  82. case 3: $errorDesc = "Ocurrió un error al cancelar el documento."; break;
  83. }
  84. }
  85. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  86. switch ($_GET["ok"]){
  87. case 0: $successDesc = "El documento se canceló correctamente."; break;
  88. }
  89. }
  90. ?>
  91. <main class="container-fluid content marco">
  92. <?php include_once("../include/errorMessage.php");?>
  93. <?php include("../include/periodoCambio.php");?>
  94. <?php if($_SESSION["periodo_id"] != "" && count($insignias_rs) > 0){ ?>
  95. <!-- Filtro -->
  96. <div class="row">
  97. <div class="col-12">
  98. <form action="constancias_gema.php" method="post">
  99. <div class="form-box form-box-info">
  100. <div class="form-group row">
  101. <label for="fecha_inicial" class="col-4 col-form-label">Tipo de evento</label>
  102. <div class="col-8 col-sm-4">
  103. <div class="datalist datalist-select mb-1 w-100">
  104. <div class="datalist-input">Ver todos</div>
  105. <span class="ing-buscar icono"></span>
  106. <ul style="display:none">
  107. <li data-id="">Ver todos</li>
  108. <?php foreach($tipo_rs as $tipo) {?>
  109. <li data-id="<?php echo $tipo["InsigniaTipo_id"];?>" <?php if(isset($filter_tipo) && $filter_tipo == $tipo["InsigniaTipo_id"]){echo "class='selected'";}?>><?php echo $tipo["InsigniaTipo_desc"];?></li>
  110. <?php }?>
  111. </ul>
  112. <input type="hidden" id="tipo" name="tipo" value="">
  113. </div>
  114. </div>
  115. </div>
  116. </div>
  117. <div class="form-group row mt-4">
  118. <div class="col-12 text-center">
  119. <button type="submit" class="btn btn-outline-primary"><?php echo $ICO["buscar"]; ?> Filtrar</button>
  120. <button type="button" class="btn btn-outline-danger btn-reset"><?php echo $ICO["borrar"]?> Limpiar</button>
  121. </div>
  122. </div>
  123. </form>
  124. </div>
  125. </div>
  126. <!-- end Filtro -->
  127. <form action="constancias_gema_alta.php" method="post" id="formaConstancia">
  128. <input type="hidden" id="evento" name="evento" value="">
  129. <input type="hidden" id="evento_desc" name="evento_desc" value="">
  130. <input type="hidden" id="doc_desc" name="doc_desc" value="">
  131. <input type="hidden" id="doc_id" name="doc_id" value="">
  132. </form>
  133. <div class="row">
  134. <?php
  135. foreach($insignias_rs as $evento){
  136. ?>
  137. <div class="col-6 col-sm-4">
  138. <div class="card mt-3 card-tipo">
  139. <div class="card-header">
  140. <h5 class="card-title text-center mb-1">
  141. <span style="color:<?php echo $evento["InsigniaTipo_color"];?>!important" title="<?php echo $evento["InsigniaTipo_desc"]; ?>"><?php echo $ICO["circulo"];?></span>
  142. <?php echo $evento["Insignia_titulo"]; ?></h5>
  143. </div>
  144. <div class="card-body">
  145. <p class="card-text"><b>Total:</b> <?php echo $evento["InsigniaAlumno_total"];?></p>
  146. <p class="text-center mb-0"><button class="btn btn-outline-primary btn-tipo" data-evento="<?php echo $evento["Insignia_id"]; ?>" data-evento_desc="<?php echo $evento["Insignia_titulo"]; ?>" data-doc_id="1" data-doc_desc="Constancia">Generar Constancias</button></p>
  147. </div>
  148. </div>
  149. </div>
  150. <?php } ?>
  151. </div>
  152. <?php }?>
  153. </main>
  154. <!--- FOOTER--->
  155. <?php require_once("../include/footer.php"); ?>
  156. </div>
  157. <script src="../js/jquery.min.js"></script>
  158. <script src="../js/bootstrap/popper.min.js"></script>
  159. <script src="../js/bootstrap/bootstrap.min.js"></script>
  160. <script src="../js/sidebarmenu.js"></script>
  161. <script src="../js/datalist.js"></script>
  162. <script>
  163. $(document).on( "click", ".btn-reset", function(event){
  164. var forma = $(this).parents("form");
  165. forma.find("input[type=text]").val("");
  166. forma.submit();
  167. });
  168. $(document).ready(function(){
  169. setDatalist("#periodo", <?php echo $_SESSION["periodo_id"]; ?>);
  170. $(document).on('click', '#dlPeriodo ul li' ,function(){
  171. $("#formaPeriodo").submit();
  172. });
  173. });
  174. </script>
  175. <script>
  176. $(document).ready(function(){
  177. <?php if(empty($filter_tipo)){?>
  178. setDatalistFirst("#tipo");
  179. <?php }else{?>
  180. setDatalist("#tipo", <?php echo $filter_tipo;?>);
  181. <?php } ?>
  182. $(".btn-tipo").click(function(){
  183. var btn = $(this);
  184. $("#evento").val(btn.data("evento"));
  185. $("#evento_desc").val(btn.data("evento_desc"));
  186. $("#doc_desc").val(btn.data("doc_desc"));
  187. $("#doc_id").val(btn.data("doc_id"));
  188. $("#formaConstancia").submit();
  189. });
  190. });
  191. </script>
  192. </body>
  193. </html>