alumnospromocion_editar.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390
  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 = 10;
  8. $submenu = 105;
  9. //--- Objeto para validar usuario. El id de usuario lo lee desde sesión
  10. $objSesion = new ValidaSesion($pdo, $submenu, GEMA);
  11. if(!$objSesion->tieneAcceso() || !$objSesion->puedeEditar()){
  12. header("Location: main.php");
  13. exit;
  14. }
  15. $pag = "alumnospromocion.php";
  16. if(!isset($_GET["id"])){
  17. header("Location: ".$pag."?error=0");
  18. exit;
  19. }
  20. $usr_id = filter_input(INPUT_GET, "id", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  21. /*if($usr_id == $_SESSION["usuario_id"]){
  22. header("Location: ".$pag);
  23. exit;
  24. }*/
  25. $stmt = $pdo->prepare('Select * from fs_alumno(:usr, NULL)');
  26. $stmt->bindParam(":usr", $usr_id);
  27. if(!$stmt->execute()){
  28. //print_r($stmt->errorInfo());
  29. header("Location: ".$pag."&error=2");
  30. exit;
  31. }
  32. $usuario_rs = $stmt->fetch();
  33. $stmt->closeCursor();
  34. ?>
  35. <!DOCTYPE html>
  36. <html lang="es" prefix="og: http://ogp.me/ns#">
  37. <head>
  38. <title>GEMA - Facultad de Ingeniería</title>
  39. <meta charset="utf-8">
  40. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  41. <link rel="icon" type="image/png" href="../img/favicon.png" />
  42. <link rel="stylesheet" href="../css/bootstrap-ulsa.min.css" type="text/css">
  43. <link rel="stylesheet" href="../css/indivisa.css" type="text/css">
  44. <link rel="stylesheet" href="../css/sgi.css?rand=<?php echo rand();?>" type="text/css">
  45. <link rel="stylesheet" href="../css/fa_all.css" type="text/css">
  46. <link rel="stylesheet" href="../css/jquery-ui.css" type="text/css">
  47. <link rel="stylesheet" href="../css/month-picker.css" type="text/css">
  48. <link rel="stylesheet" href="../css/calendar.css" type="text/css">
  49. </head>
  50. <body>
  51. <div>
  52. <?php
  53. //--- Objeto que pinta menu
  54. $menuObj = new MainMenu($_SESSION["usuario_id"], $menu, $pdo, GEMA, "Editar Alumno");//usr, menu, pdo, sist
  55. $menuObj->printMenu();
  56. //Tipo contacto
  57. $stmt = $pdo->prepare('Select * from fs_tipocontacto(NULL)');
  58. if(!$stmt->execute()){
  59. $errorDesc = "Ocurrió un error al cargar los tipos de contacto";
  60. }else{
  61. $tipocontacto_rs = $stmt->fetchAll();
  62. }
  63. $stmt->closeCursor();
  64. //Perfil contacto
  65. $stmt = $pdo->prepare('Select * from fs_perfilcontacto(NULL)');
  66. if(!$stmt->execute()){
  67. $errorDesc = "Ocurrió un error al cargar los tipos de contacto";
  68. }else{
  69. $perfilcontacto_rs = $stmt->fetchAll();
  70. }
  71. $stmt->closeCursor();
  72. //Datos de contacto
  73. $stmt = $pdo->prepare('Select * from fs_contacto(:usr_id, NULL, NULL)');//selecciona contactos
  74. $stmt->bindParam(":usr_id", $usr_id);
  75. if(!$stmt->execute()){
  76. $errorDesc = "Ocurrió un error al cargar los datos de contacto del alumno";
  77. print_r($stmt->errorInfo());
  78. }else{
  79. $contacto_rs = $stmt->fetchAll();
  80. }
  81. $stmt->closeCursor();
  82. //Plan de estudios asignables
  83. $stmt = $pdo->prepare('Select * from fs_planestudio_alumnos(NULL, NULL, true)');
  84. if(!$stmt->execute()){
  85. $errorDesc = "Ocurrió un error al cargar los planes de estudio";
  86. }else{
  87. $plan_rs = $stmt->fetchAll();
  88. }
  89. $stmt->closeCursor();
  90. //Plan de estudios asignados
  91. $stmt = $pdo->prepare('Select * from fs_alumno_planestudio(:usr_id, NULL)');
  92. $stmt->bindParam(":usr_id", $usr_id);
  93. if(!$stmt->execute()){
  94. $errorDesc = "Ocurrió un error al cargar los planes de estudio";
  95. }else{
  96. $carrera_rs = $stmt->fetchAll();
  97. }
  98. $stmt->closeCursor();
  99. //Procedencia
  100. $stmt = $pdo->prepare('Select * from fs_tipoprocedencia(NULL)');
  101. if(!$stmt->execute()){
  102. $errorDesc = "Ocurrió un error al cargar los tipos de instituciones de procedencia del alumno";
  103. }else{
  104. $procedencia_rs = $stmt->fetchAll();
  105. }
  106. $stmt->closeCursor();
  107. //--Manejo de errores y mensajes de exito
  108. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  109. switch ($_GET["error"]){
  110. case 0: $errorDesc = "No se reciberon los datos del alumno."; break;
  111. case 1: $errorDesc = "Ocurrió un error al actualizar los datos del alumno. Los prámetros pueden ser incorrectos"; break;
  112. case 2: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  113. case 3: $errorDesc = "Ocurrió un error al actualizar los programas de estudio del alumno."; break;
  114. case 4: $errorDesc = "No se puede borrar el programa académico porque tiene materias o calificaciones asignadas."; break;
  115. case 5: $errorDesc = "Ya existe un alumno con ese CURP. Los cambios no se aplicaron. Revisa los datos actuales"; break;
  116. }
  117. }
  118. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  119. switch ($_GET["ok"]){
  120. case 0: $successDesc = "Los datos del alumno se actualizaron correctamente."; break;
  121. }
  122. }
  123. ?>
  124. <main class="container-fluid content marco">
  125. <?php include_once("../include/errorMessage.php");?>
  126. <?php if(isset($plan_rs, $carrera_rs)){
  127. ?>
  128. <div class="row">
  129. <div class="col-12">
  130. <form action="./action/alumnospromocion_update.php" method="post" id="formaModal" onsubmit="return validaForm()">
  131. <input type="hidden" name="id" value="<?php echo $usr_id ?>" />
  132. <div class="form-box form-box-info">
  133. <div class="form-group row">
  134. <label for="apellidos" class="col-4 col-form-label">Apellidos *</label>
  135. <div class="col-8 col-sm-4">
  136. <input id="apellidos" name="apellidos" type="text" class="form-control" required="required" maxlength="40" value="<?php echo $usuario_rs["Usuario_apellidos"]; ?>">
  137. </div>
  138. </div>
  139. <div class="form-group row">
  140. <label for="nombre" class="col-4 col-form-label">Nombre *</label>
  141. <div class="col-8 col-sm-4">
  142. <input id="nombre" name="nombre" type="text" class="form-control" required="required" maxlength="30" value="<?php echo $usuario_rs["Usuario_nombre"]; ?>">
  143. </div>
  144. </div>
  145. <div class="form-group row">
  146. <label for="curp" class="col-4 col-form-label">CURP</label>
  147. <div class="col-8 col-sm-4">
  148. <input id="curp" name="curp" type="text" class="form-control" readonly="readonly" maxlength="25" value="<?php echo $usuario_rs["Usuario_curp"]; ?>">
  149. </div>
  150. </div>
  151. </div>
  152. <div class="row">
  153. <div class="col-12 my-4"><h3>Programa académico</h3></div>
  154. </div>
  155. <div class="row" id="carrera-block">
  156. <?php
  157. $id =1;
  158. foreach($carrera_rs as $carrera){
  159. ?>
  160. <div class="col-12 col-sm-6 form-box">
  161. <div class="form-group row">
  162. <label class="col-4 col-form-label">Estado</label>
  163. <div class="col-8 pt-1" style="color:<?php echo $carrera["EstadoAlumno_color"];?>">
  164. <?php echo $carrera["EstadoAlumno_desc"]." - ".$carrera["SubEstadoAlumno_desc"]; ?>
  165. </div>
  166. </div>
  167. <div class="form-group row">
  168. <label for="plan<?php echo $id; ?>" class="col-4 col-form-label">Carrera</label>
  169. <div class="col-8 pt-1">
  170. <?php echo $carrera["Carrera_desc"]." ".$carrera["PlanEstudio_desc"]; ?>
  171. </div>
  172. </div>
  173. <div class="form-group row clave-group">
  174. <label for="clave<?php echo $id; ?>" class="col-4 col-form-label">Clave ULSA</label>
  175. <div class="col-8 pt-1">
  176. <?php echo $carrera["Usuario_claveULSA"]; ?>
  177. </div>
  178. </div>
  179. <div class="form-group row ingreso-group">
  180. <label for="ingreso<?php echo $id; ?>" class="col-4 col-form-label">Fecha ingreso *</label>
  181. <div class="col-8 pt-1">
  182. <?php echo fechaMonthPicker($carrera["Alumno_fecha_ingreso"]); ?>
  183. </div>
  184. </div>
  185. <div class="form-group row ingreso-group">
  186. <label for="generacion<?php echo $id; ?>" class="col-4 col-form-label">Generación *</label>
  187. <div class="col-8 pt-1">
  188. <?php echo fechaMonthPicker($carrera["Alumno_generacion"]); ?>
  189. </div>
  190. </div>
  191. </div>
  192. <?php
  193. $id++;
  194. } ?>
  195. </div><!-- row -->
  196. <div class="my-5 p-4 bg-light">
  197. <div class="row">
  198. <div class="col-12 mb-3"><h3>Contacto</h3></div>
  199. </div>
  200. <div id="contacto_list" class="col-12 px-0">
  201. <div class="form-group row contacto d-none">
  202. <div class="col-2 px-1">
  203. <select name="contacto_tipo[]" class="form-control tipo" disabled="true" readonly="true">
  204. <?php foreach($tipocontacto_rs as $tipocontacto) {?>
  205. <option value="<?php echo $tipocontacto["TipoContacto_id"];?>" data-subtipo="<?php echo $tipocontacto["SubtipoContacto"];?>"><?php echo $tipocontacto["TipoContacto_desc"];?></option>
  206. <?php } ?>
  207. </select>
  208. </div>
  209. <div class="col-2 px-1">
  210. <select name="contacto_perfil[]" class="form-control" disabled="true" readonly="true">
  211. <?php foreach($perfilcontacto_rs as $tipocontacto) {?>
  212. <option value="<?php echo $tipocontacto["PerfilContacto_id"];?>" <?php if($tipocontacto["PerfilContacto_seleccionado"]){echo 'checked="checked"';}?>><?php echo $tipocontacto["PerfilContacto_desc"];?></option>
  213. <?php } ?>
  214. </select>
  215. </div>
  216. <div class="col-2 px-1 d-none">
  217. <select name="contacto_subtipo[]" class="form-control subtipo" disabled="true" readonly="true">
  218. </select>
  219. </div>
  220. <div class="col px-1">
  221. <input name="contacto_valor[]" type="text" class="form-control" maxlength="100" placeholder="Valor" disabled="true" readonly="true">
  222. </div>
  223. <div class="col-1">
  224. <button type="button" class="btn btn-outline-danger borra-contacto"><?php echo $ICO["borrar2"];?> </button>
  225. </div>
  226. </div>
  227. <?php
  228. foreach($contacto_rs as $contacto){ ?>
  229. <div class="form-group row contacto">
  230. <div class="col-2 px-1">
  231. <select name="contacto_tipo[]" class="form-control tipo">
  232. <?php foreach($tipocontacto_rs as $tipocontacto) {
  233. $selected = ($contacto["TipoContacto_id"] == $tipocontacto["TipoContacto_id"]) ? "selected='selected'":"";
  234. ?>
  235. <option <?php echo $selected;?> value="<?php echo $tipocontacto["TipoContacto_id"];?>" data-subtipo="<?php echo $tipocontacto["SubtipoContacto"];?>"><?php echo $tipocontacto["TipoContacto_desc"];?></option>
  236. <?php } ?>
  237. </select>
  238. </div>
  239. <div class="col-2 px-1">
  240. <select name="contacto_perfil[]" class="form-control">
  241. <?php foreach($perfilcontacto_rs as $tipocontacto) {
  242. $selected = ($contacto["PerfilContacto_id"] == $tipocontacto["PerfilContacto_id"]) ? "selected='selected'":"";
  243. ?>
  244. <option <?php echo $selected;?> value="<?php echo $tipocontacto["PerfilContacto_id"];?>" <?php if($tipocontacto["PerfilContacto_seleccionado"]){echo 'checked="checked"';}?>><?php echo $tipocontacto["PerfilContacto_desc"];?></option>
  245. <?php } ?>
  246. </select>
  247. </div>
  248. <?php
  249. //Subipo contacto
  250. $stmt = $pdo->prepare('Select * from fs_subtipocontacto(:tipo, NULL)');
  251. $stmt->bindParam(":tipo", $contacto["TipoContacto_id"]);
  252. if(!$stmt->execute()){
  253. $errorDesc = "Ocurrió un error al cargar los tipos de contacto";
  254. $subtipocontacto_rs = array();
  255. }else{
  256. $subtipocontacto_rs = $stmt->fetchAll();
  257. }
  258. $stmt->closeCursor();
  259. if(count($subtipocontacto_rs) == 0){ ?>
  260. <div class="col-2 px-1 d-none">
  261. <select name="contacto_subtipo[]" class="form-control subtipo">
  262. </select>
  263. </div>
  264. <?php } else {?>
  265. <div class="col-2 px-1">
  266. <select name="contacto_subtipo[]" class="form-control subtipo">
  267. <?php foreach($subtipocontacto_rs as $tipocontacto) {
  268. $selected = ($contacto["SubtipoContacto_id"] == $tipocontacto["SubtipoContacto_id"]) ? "selected='selected'":"";
  269. ?>
  270. <option <?php echo $selected;?> value="<?php echo $tipocontacto["SubtipoContacto_id"];?>"><?php echo $tipocontacto["SubtipoContacto_desc"];?></option>
  271. <?php } ?>
  272. </select>
  273. </div>
  274. <?php } ?>
  275. <div class="col px-1">
  276. <input name="contacto_valor[]" type="text" class="form-control" maxlength="100" placeholder="Valor" value="<?php echo $contacto["Contacto_valor"]; ?>">
  277. </div>
  278. <div class="col-1">
  279. <button type="button" class="btn btn-outline-danger borra-contacto"><?php echo $ICO["borrar2"];?> </button>
  280. </div>
  281. </div>
  282. <?php } ?>
  283. </div>
  284. <div class="row">
  285. <div class="col-4 col-sm-2 px-1">
  286. <button type="button" class="btn btn-outline-secondary btn-block" id="agrega-contacto"><?php echo $ICO["mas"];?> Agregar</button>
  287. </div>
  288. </div>
  289. </div>
  290. <div class="form-group row mt-3">
  291. <div class="offset-4 col-8">
  292. <button type="submit" class="btn btn-outline-primary" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  293. <a href="alumnospromocion.php" class="btn btn-outline-danger"><?php echo $ICO["cancelar"];?> Cancelar</a>
  294. </div>
  295. </div>
  296. </form>
  297. </div>
  298. </div>
  299. <?php } ?>
  300. </main>
  301. <!--- FOOTER--->
  302. <?php require_once("../include/footer.php"); ?>
  303. <!-- Modal -->
  304. <div class="modal fade" id="modal_confirm" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true">
  305. <div class="modal-dialog modal-dialog-centered" role="document">
  306. <div class="modal-content">
  307. <div class="modal-body">
  308. <div class="row">
  309. <div class="col">
  310. <p class="font-weight-bold">¿Estás seguro de que quieres quitar el programa académico del alumno?</p>
  311. <p>Sólo se puede quitar si no tiene materias asignadas.</p>
  312. </div>
  313. </div>
  314. </div>
  315. <div class="modal-footer">
  316. <input type="hidden" id="planbox_borrar" value="">
  317. <button type="button" class="btn btn-outline-primary" id="btn-borrar"><?php echo $ICO["aceptar"];?> Borrar</button>
  318. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"];?> Cancelar</button>
  319. </div>
  320. </div>
  321. </div>
  322. </div>
  323. </div>
  324. <script src="../js/jquery.min.js"></script>
  325. <script src="../js/jquery-ui.js"></script>
  326. <script src="../js/datepicker-es.js"></script>
  327. <script src="../js/month-picker.js"></script>
  328. <script src="../js/bootstrap/popper.min.js"></script>
  329. <script src="../js/bootstrap/bootstrap.min.js"></script>
  330. <script src="../js/fechas.js"></script>
  331. <script src="../js/util.js"></script>
  332. <script src="../js/sidebarmenu.js"></script>
  333. <script src="./js/contacto.js"></script>
  334. <script>
  335. //var datepickerOptions = { dateFormat: "dd/mm/yy", changeMonth: true, changeYear: true};
  336. var tieneNueva = false;
  337. function validaForm(){
  338. $("#contacto_list >.contacto:first-child").remove();
  339. return true;
  340. }
  341. $(document).ready(function(){
  342. /*$(".date-picker" ).datepicker(datepickerOptions);
  343. $(".date-picker" ).datepicker( $.datepicker.regional[ "es" ] );*/
  344. $('.date-picker').MonthPicker({ Button: false, MaxMonth: 2, MonthFormat: 'M, yy', AltFormat: 'yy-mm-dd'});
  345. $.each($('.date-picker'), function(index){
  346. if($(this).siblings("input[type=hidden]").length > 0){
  347. var oculto = '#'+$(this).siblings("input[type=hidden]").prop("id");
  348. $(this).MonthPicker('option', {'AltField': oculto });
  349. }
  350. });
  351. });
  352. </script>
  353. </body>
  354. </html>