materias_crear.php 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858
  1. <?php
  2. require_once("../include/constantes.php");
  3. require_once("../include/bd_pdo.php");
  4. require_once("../classes/ValidaSesion.php");
  5. require_once("../classes/MainMenu.php");
  6. $menu = 6;
  7. $submenu = 65;
  8. //--- Objeto para validar usuario. El id de usuario lo lee desde sesión
  9. $objSesion = new ValidaSesion($pdo, $submenu, APSA);
  10. if(!$objSesion->tieneAcceso() || !$objSesion->puedeEditar()){
  11. header("Location: main.php");
  12. exit;
  13. }
  14. ?>
  15. <!DOCTYPE html>
  16. <html lang="es" prefix="og: http://ogp.me/ns#">
  17. <head>
  18. <title>APSA - Facultad de Ingeniería</title>
  19. <meta charset="utf-8">
  20. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  21. <link rel="icon" type="image/png" href="../img/favicon.png" />
  22. <link rel="stylesheet" href="../css/bootstrap-ulsa.min.css" type="text/css">
  23. <link rel="stylesheet" href="../css/indivisa.css" type="text/css">
  24. <link rel="stylesheet" href="../css/sgi.css?rand=<?php echo rand();?>" type="text/css">
  25. <link rel="stylesheet" href="../css/fa_all.css" type="text/css">
  26. <link rel="stylesheet" href="../css/jquery-ui.css" type="text/css">
  27. <link rel="stylesheet" href="../css/calendar.css" type="text/css">
  28. <link rel="stylesheet" href="../css/toggle.css" type="text/css">
  29. </head>
  30. <body>
  31. <div>
  32. <?php
  33. //--- Objeto que pinta menu
  34. $menuObj = new MainMenu($_SESSION["usuario_id"], $menu, $pdo, APSA, "Crear Materias");//usr, menu, pdo, sist
  35. $menuObj->printMenu();
  36. //Area
  37. $stmt = $pdo->prepare('Select * from fs_areaacademica(NULL, NULL)');
  38. //$stmt->bindParam(":nivel", $_SESSION["nivel_id"]);
  39. if(!$stmt->execute()){
  40. $errorDesc = "Ocurrió un error al cargar las áreas académicas";
  41. }else{
  42. $area_rs = $stmt->fetchAll();
  43. }
  44. $stmt->closeCursor();
  45. //Plan
  46. $stmt = $pdo->prepare('Select * from fs_planestudio(NULL, NULL, NULL, true, 0, NULL)');
  47. //$stmt->bindParam(":nivel", $_SESSION["nivel_id"]);
  48. if(!$stmt->execute()){
  49. $errorDesc = "Ocurrió un error al cargar los planes de estudio";
  50. }else{
  51. $plan_rs = $stmt->fetchAll();
  52. }
  53. $stmt->closeCursor();
  54. //Tipo Submateria
  55. $stmt = $pdo->prepare('Select * from fs_tiposubmateria(NULL)');
  56. if(!$stmt->execute()){
  57. $errorDesc = "Ocurrió un error al cargar el tipo de submateria";
  58. }else{
  59. $tiposub_rs = $stmt->fetchAll();
  60. }
  61. $stmt->closeCursor();
  62. $stmt = null;
  63. //Tipo ODS
  64. $stmt = $pdo->prepare('Select * from fs_ods(NULL)');
  65. if(!$stmt->execute()){
  66. $errorDesc = "Ocurrió un error al cargar los ODS";
  67. }else{
  68. $ods_rs = $stmt->fetchAll();
  69. }
  70. $stmt->closeCursor();
  71. $stmt = null;
  72. //--Manejo de errores y mensajes de exito
  73. if(isset($_GET["error"]) && is_numeric($_GET["error"])){
  74. switch ($_GET["error"]){
  75. case 0: $errorDesc = "No se reciberon los datos de la materia."; break;
  76. case 1: $errorDesc = "Ocurrió un error al insertar los datos de la materia. Los prámetros pueden ser incorrectos"; break;
  77. case 2: $errorDesc = "Ocurrió un error al actualizar los datos de la materia."; break;
  78. case 3: $errorDesc = "No tienes permisos para realizar esa acción."; break;
  79. case 4: $errorDesc = "Seleccionaste electivas para la materia, pero no agregaste ninguna."; break;
  80. case 5: $errorDesc = "Ocurrió un error al insertar los datos de la submateria. Los prámetros pueden ser incorrectos"; break;
  81. case 6: $errorDesc = "Ocurrió un error al insertar los datos de las materias relacionadas."; break;
  82. case 7: $errorDesc = "Ocurrió un error al insertar los atributos de egreso."; break;
  83. case 8: $errorDesc = "Ocurrió un error al actualizar los atributos de egreso."; break;
  84. case 9: $errorDesc = "Ocurrió un error al insertar el ODS."; break;
  85. }
  86. }
  87. if(isset($_GET["ok"]) && is_numeric($_GET["ok"])){
  88. switch ($_GET["ok"]){
  89. case 0: $successDesc = "La materia se guardó correctamente."; break;
  90. case 1: $successDesc = "La materia se actualizó correctamente."; break;
  91. }
  92. }
  93. ?>
  94. <main class="container-fluid content marco">
  95. <?php include_once("../include/errorMessage.php");?>
  96. <?php if(isset($plan_rs) && isset($area_rs) && isset($tiposub_rs)){
  97. ?>
  98. <div class="row">
  99. <div class="col-12">
  100. <form action="./action/materia_insert.php" method="post" id="formaModal" onsubmit="submitForm()">
  101. <div class="form-box">
  102. <div class="form-group row">
  103. <label for="desc" class="col-4 col-form-label">Nombre *</label>
  104. <div class="col-8 col-sm-4">
  105. <input id="desc" name="desc" type="text" class="form-control" required="required" maxlength="100">
  106. </div>
  107. </div>
  108. <div class="form-group row">
  109. <label for="clave" class="col-4 col-form-label">Clave *</label>
  110. <div class="col-8 col-sm-4">
  111. <input id="clave" name="clave" type="text" class="form-control" required="required" maxlength="15">
  112. </div>
  113. </div>
  114. <div class="form-group row">
  115. <label for="area" class="col-4 col-form-label">Área *</label>
  116. <div class="col-8 col-sm-4">
  117. <!--<select name="area" id="area" class="form-control" required="required">
  118. <?php foreach($area_rs as $area) {?>
  119. <option value="<?php echo $area["Area_id"];?>"><?php echo $area["Area_desc"];?></option>
  120. <?php } ?>
  121. </select>-->
  122. <div class="datalist datalist-select mb-1 w-100">
  123. <div class="datalist-input">&nbsp;</div>
  124. <span class="ing-buscar icono"></span>
  125. <ul style="display:none">
  126. <?php foreach($area_rs as $area) { ?>
  127. <li data-id="<?php echo $area["Area_id"];?>" ><?php echo $area["Area_desc"]?></li>
  128. <?php }?>
  129. </ul>
  130. <input type="hidden" id="area" name="area" value="">
  131. </div>
  132. </div>
  133. </div>
  134. <div class="form-group row">
  135. <label for="plan" class="col-4 col-form-label">Plan de estudios *</label>
  136. <div class="col-8 col-sm-4">
  137. <!--<select name="plan" id="plan" class="form-control" required="required">
  138. <?php foreach($plan_rs as $plan) {?>
  139. <option value="<?php echo $plan["PlanEstudio_id"];?>" data-nivel="<?php echo $plan["Nivel_id"]; ?>" ><?php echo $plan["Carrera_desc"]." - ".$plan["PlanEstudio_desc"];?></option>
  140. <?php } ?>
  141. </select>-->
  142. <div class="datalist datalist-select mb-1 w-100" id="dlPlan">
  143. <div class="datalist-input">&nbsp;</div>
  144. <span class="ing-buscar icono"></span>
  145. <ul style="display:none">
  146. <?php
  147. $last_nivel = -1;
  148. foreach($plan_rs as $plan){
  149. if($last_nivel != intval($plan["Nivel_id"])){
  150. $last_nivel = intval($plan["Nivel_id"]);
  151. ?>
  152. <li data-id="" class="not-selectable"><?php echo $plan["Nivel_desc"]; ?></li>
  153. <?php } ?>
  154. <li data-nivel="<?php echo $plan["Nivel_id"];?>" data-id="<?php echo $plan["PlanEstudio_id"];?>" class="pl-4"><?php echo $plan["Carrera_desc"]." - ".$plan["PlanEstudio_desc"];?></li>
  155. <?php }?>
  156. </ul>
  157. <input type="hidden" id="plan" name="plan" value="">
  158. </div>
  159. </div>
  160. </div>
  161. <div class="form-group row">
  162. <label for="gpo" class="col-4 col-form-label">Grupo de posgrado</label>
  163. <div class="col-8 col-sm-4">
  164. <input id="gpo" name="gpo" type="text" class="form-control" maxlength="10">
  165. </div>
  166. </div>
  167. <div class="form-group row">
  168. <label for="sem" class="col-4 col-form-label"><span id="sem_texto">Semestres</span> *</label>
  169. <div class="col-8 col-sm-4">
  170. <select name="sem" id="sem" class="form-control" required="required">
  171. <option value="0">-Indistinto-</option>
  172. <option value="-1">Propedéutico</option>
  173. </select>
  174. <!--<div class="datalist datalist-select mb-1 w-100">
  175. <div class="datalist-input">&nbsp;</div>
  176. <span class="ing-buscar icono"></span>
  177. <ul style="display:none">
  178. <li data-id="0">Indistinto</li>
  179. <li data-id="-1">Propedéutico</li>
  180. </ul>
  181. <input type="hidden" id="sem" name="sem" value="">
  182. </div>-->
  183. </div>
  184. </div>
  185. <div class="form-group row">
  186. <label for="horas_clase" class="col-4 col-form-label">Horas de clase</label>
  187. <div class="col-8 col-sm-4">
  188. <input id="horas_clase" name="horas_clase" type="text" class="form-control" maxlength="4" value="3.0">
  189. </div>
  190. </div>
  191. <!--<div class="form-group row">
  192. <label for="horas_lab" class="col-4 col-form-label">Horas de laboratorio</label>
  193. <div class="col-4">
  194. <input id="horas_lab" name="horas_lab" type="text" class="form-control" required="required" maxlength="4">
  195. </div>
  196. </div>-->
  197. <div class="form-group row">
  198. <label for="creditos" class="col-4 col-form-label">Créditos</label>
  199. <div class="col-8 col-sm-4">
  200. <input id="creditos" name="creditos" type="text" class="form-control" required="required" maxlength="5" value="5.25">
  201. </div>
  202. </div>
  203. </div>
  204. <h3>Electivas</h3>
  205. <div class="form-group row">
  206. <label for="tiposub" class="col-4 col-form-label">Tipo de submaterias</label>
  207. <div class="col-8">
  208. <input type="checkbox" data-toggle="toggle" data-onstyle="success" data-offstyle="light" data-on="Electivas" data-off="Sin electivas" id="tiposub" name="tiposub" value="2">
  209. </div>
  210. </div>
  211. <div class="row">
  212. <div class="col">
  213. <div <?php if(!isset($submateria_rs) || count($submateria_rs) == 0){?> class="collapse" <?php } ?> id="submateria">
  214. <p>Selecciona las electivas para la materia:</p>
  215. <div class="form-group row">
  216. <div class="col-10">
  217. <select name="electiva[]" id="electiva" class="form-control" multiple="multiple" size="5">
  218. <?php foreach($submateria_rs as $sub){ ?>
  219. <option value="<?php echo $sub["Submateria_id"];?>"><?php echo $sub["Submateria_desc"];?></option>
  220. <?php } ?>
  221. </select>
  222. </div>
  223. <div class="col-2">
  224. <p>
  225. <button type="button" class="btn btn-outline-primary modal-open-electiva"electiva><?php echo $ICO["buscar"]?> Buscar</button>
  226. </p>
  227. <p>
  228. <button type="button" class="btn btn-outline-danger btn-quita-electiva"><?php echo $ICO["menos"]?> Quitar</button>
  229. </p>
  230. </div>
  231. </div>
  232. </div>
  233. </div>
  234. </div>
  235. <hr/>
  236. <div id="atributos_block">
  237. <h3>Atributos de egreso</h3>
  238. <p>Elige los principales atributos de egreso con los que colabora la materia. <strong>Se sugieren máximo 2</strong>.</p>
  239. <div class="form-group row">
  240. <div class="col-10">
  241. <select name="atributos[]" id="atributos" class="form-control" multiple="multiple" size="3"></select>
  242. </div>
  243. <div class="col-2">
  244. <p>
  245. <button type="button" class="btn btn-outline-primary modal-open-atributos"><?php echo $ICO["buscar"]?> Buscar</button>
  246. </p>
  247. <p>
  248. <button type="button" class="btn btn-outline-danger btn-quita-atributos"><?php echo $ICO["menos"]?> Quitar</button>
  249. </p>
  250. </div>
  251. </div>
  252. </div>
  253. <?php if(isset($ods_rs)){ ?>
  254. <hr/>
  255. <h3>ODS</h3>
  256. <p>Elige el principal Objetivo de Desarrollo Sostenible que busca solucionar la materia.</p>
  257. <div class="form-group row">
  258. <div class="col-10">
  259. <select name="ods" id="ods" class="form-control">
  260. <option value="">- Sin ODS -</option>
  261. <?php foreach($ods_rs as $ods){?>
  262. <option value="<?php echo $ods["ODs_id"];?>"><?php echo $ods["ODs_num"].") ".$ods["ODs_desc"];?></option>
  263. <?php } ?>
  264. </select>
  265. </div>
  266. </div>
  267. <?php } ?>
  268. <hr/>
  269. <h3>Materias relacionadas</h3>
  270. <p>Agrega materias de otros planes que se relacionen con ésta materia.</p>
  271. <p>Las materias relacionadas pueden compartir profesores y salones, además se pueden vincular con los horarios de otros grupos.</p>
  272. <div class="form-group row">
  273. <div class="col-10">
  274. <select name="relacionada[]" id="relacionada" class="form-control" multiple="multiple" size="5">
  275. </select>
  276. </div>
  277. <div class="col-2">
  278. <p>
  279. <button type="button" class="btn btn-outline-primary modal-open"><?php echo $ICO["buscar"]?> Buscar</button>
  280. </p>
  281. <p>
  282. <button type="button" class="btn btn-outline-danger btn-quita-materia"><?php echo $ICO["menos"]?> Quitar</button>
  283. </p>
  284. </div>
  285. </div>
  286. <div class="form-group row">
  287. <div class="offset-4 col-8">
  288. <button type="submit" class="btn btn-outline-primary" id="submitBtn" data-tipo="1"><?php echo $ICO["aceptar"];?> Guardar</button>
  289. <a href="materias.php" class="btn btn-outline-danger"><?php echo $ICO["cancelar"];?> Cancelar</a>
  290. </div>
  291. </div>
  292. </form>
  293. </div>
  294. </div>
  295. <?php } ?>
  296. </main>
  297. <!--- FOOTER--->
  298. <?php require_once("../include/footer.php"); ?>
  299. <?php if($objSesion->puedeEditar()){ ?>
  300. <!-- Modal -->
  301. <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true" data-backdrop="static" data-keyboard="false">
  302. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  303. <div class="modal-content">
  304. <div class="modal-header">
  305. <h4 class="col-12 modal-title text-center">Busca Materia
  306. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  307. <span aria-hidden="true">&times;</span>
  308. </button></h4>
  309. </div>
  310. <div class="modal-body">
  311. <form id="forma_buscar" onsubmit="return false">
  312. <div class="form-box">
  313. <div class="form-group row">
  314. <label for="filter_desc" class="col-4 col-form-label text-right">Nombre</label>
  315. <div class="col-8">
  316. <input id="filter_desc" name="desc" type="text" class="form-control">
  317. </div>
  318. </div>
  319. <div class="form-group row">
  320. <label for="filter_area" class="col-4 col-form-label text-right">Área</label>
  321. <div class="col-8">
  322. <!--<select id="filter_area" name="area" class="form-control">
  323. <option value="">Mostrar todas</option>
  324. <?php foreach($area_rs as $area) {?>
  325. <option value="<?php echo $area["Area_id"];?>"><?php echo $area["Area_desc"]?></option>
  326. <?php } ?>
  327. </select>-->
  328. <div class="datalist datalist-select mb-1 w-100">
  329. <div class="datalist-input">Mostrar todas</div>
  330. <span class="ing-buscar icono"></span>
  331. <ul style="display:none">
  332. <li data-id="">Mostrar todas</li>
  333. <?php foreach($area_rs as $area) { ?>
  334. <li data-id="<?php echo $area["Area_id"];?>" ><?php echo $area["Area_desc"]?></li>
  335. <?php }?>
  336. </ul>
  337. <input type="hidden" id="filter_area" name="area" value="">
  338. </div>
  339. </div>
  340. </div>
  341. <div class="form-group row">
  342. <label for="filter_plan" class="col-4 col-form-label text-right">Plan de estudios</label>
  343. <div class="col-8">
  344. <!--<select id="filter_plan" name="plan" class="form-control">
  345. <option value="">Mostrar todos</option>
  346. <?php foreach($plan_rs as $plan) {?>
  347. <option value="<?php echo $plan["PlanEstudio_id"];?>" ><?php echo $plan["Carrera_desc"]." - ".$plan["PlanEstudio_desc"];?></option>
  348. <?php } ?>
  349. </select>-->
  350. <div class="datalist datalist-select mb-1 w-100">
  351. <div class="datalist-input">Mostrar todos</div>
  352. <span class="ing-buscar icono"></span>
  353. <ul style="display:none">
  354. <li data-id="">Mostrar todos</li>
  355. <?php
  356. $last_nivel = -1;
  357. foreach($plan_rs as $plan){
  358. if($last_nivel != intval($plan["Nivel_id"])){
  359. $last_nivel = intval($plan["Nivel_id"]);
  360. ?>
  361. <li data-id="" class="not-selectable"><?php echo $plan["Nivel_desc"]; ?></li>
  362. <?php } ?>
  363. <li data-id="<?php echo $plan["PlanEstudio_id"];?>" class="pl-4"><?php echo $plan["Carrera_desc"]." - ".$plan["PlanEstudio_desc"];?></li>
  364. <?php }?>
  365. </ul>
  366. <input type="hidden" id="filter_plan" name="plan" value="">
  367. </div>
  368. </div>
  369. </div>
  370. </div>
  371. <div class="form-group row">
  372. <div class="offset-4">
  373. <button type="submit" class="btn btn-outline-primary" id="btn-busca"><?php echo $ICO["buscar"]; ?> Buscar</button>
  374. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"]; ?> Cerrar</button>
  375. </div>
  376. </div>
  377. </form>
  378. <p>Se mostrarán los primeros <strong><?php echo MAX_ROWS;?></strong> resultados.</p>
  379. <table class="table table-sm table-striped table-white">
  380. <thead class="thead-dark">
  381. <tr>
  382. <th>Materia</th>
  383. <th>Área</th>
  384. <th>Plan</th>
  385. <th>Semestre</th>
  386. <th></th>
  387. </tr>
  388. </thead>
  389. <tbody id="table-result">
  390. <tr class="materia-row">
  391. <td class="mat-desc"></td>
  392. <td class="mat-area"></td>
  393. <td class="mat-plan"></td>
  394. <td class="mat-sem text-center"></td>
  395. <td class="mat-agrega text-center"><button type="button" class="btn btn-outline-primary btn-sm d-none btn-agrega-materia"><?php echo $ICO["mas"]; ?></button></td>
  396. </tr>
  397. </tbody>
  398. </table>
  399. </div>
  400. </div>
  401. </div>
  402. </div>
  403. <div class="modal fade" id="modal-electiva" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true" data-backdrop="static" data-keyboard="false">
  404. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  405. <div class="modal-content">
  406. <div class="modal-header">
  407. <h4 class="col-12 modal-title text-center">Busca Electiva
  408. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  409. <span aria-hidden="true">&times;</span>
  410. </button></h4>
  411. </div>
  412. <div class="modal-body">
  413. <form id="forma_buscar-electiva" onsubmit="return false">
  414. <div class="form-box">
  415. <div class="form-group row">
  416. <label for="filter_desc-electiva" class="col-4 col-form-label text-right">Nombre</label>
  417. <div class="col-8">
  418. <input id="filter_desc-electiva" name="desc" type="text" class="form-control">
  419. </div>
  420. </div>
  421. </div>
  422. <div class="form-group row">
  423. <div class="offset-4">
  424. <button type="submit" class="btn btn-outline-primary" id="btn-busca-electiva"><?php echo $ICO["buscar"]; ?> Buscar</button>
  425. <button type="button" class="btn btn-outline-danger" data-dismiss="modal" aria-label="Close"><?php echo $ICO["cancelar"]; ?> Cerrar</button>
  426. </div>
  427. </div>
  428. </form>
  429. <p>Se mostrarán los primeros <strong><?php echo MAX_ROWS;?></strong> resultados.</p>
  430. <table class="table table-sm table-striped table-white">
  431. <thead class="thead-dark">
  432. <tr>
  433. <th>Electiva</th>
  434. <th></th>
  435. </tr>
  436. </thead>
  437. <tbody id="table-result-electiva">
  438. <tr class="materia-row">
  439. <td class="mat-desc"></td>
  440. <td class="mat-agrega text-center"><button type="button" class="btn btn-outline-primary btn-sm d-none btn-agrega-electiva"><?php echo $ICO["mas"]; ?></button></td>
  441. </tr>
  442. </tbody>
  443. </table>
  444. </div>
  445. </div>
  446. </div>
  447. </div>
  448. <div class="modal fade" id="modal-atributos" tabindex="-1" role="dialog" aria-labelledby="modal" aria-hidden="true" data-backdrop="static" data-keyboard="false">
  449. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  450. <div class="modal-content">
  451. <div class="modal-header">
  452. <h4 class="col-12 modal-title text-center">Atributos de egreso
  453. <button type="button" class="close text-white" data-dismiss="modal" aria-label="Close">
  454. <span aria-hidden="true">&times;</span>
  455. </button></h4>
  456. </div>
  457. <div class="modal-body">
  458. <div id="sinatributos_block">
  459. <h4 class="text-danger text-center"><span class="ing-importante"></span> El plan de estudios no tiene atributos de egreso registrados</h4>
  460. </div>
  461. <div id="conatributos_block">
  462. <table class="table table-sm table-striped table-white">
  463. <thead class="thead-dark">
  464. <tr>
  465. <th>Atributo</th>
  466. <th style="width:165px">Nivel de logro</th>
  467. </tr>
  468. </thead>
  469. <tbody id="table-result-atributos">
  470. <tr class="atributo-row">
  471. <td class="atributo-desc"></td>
  472. <td class="atributo-agrega text-center align-middle">
  473. <div class="input-group mb-3">
  474. <?php
  475. //Obtiene niveles de atributos de egreso
  476. $stmt = $pdo->prepare('Select * from fs_atributoegreso_nivel(NULL)');
  477. if(!$stmt->execute()){
  478. //print_r($stmt->errorInfo());
  479. $errorDesc = "Ocurrió un error al cargar los atribuos de egreso";
  480. }else{
  481. $nivel_rs = $stmt->fetchAll();
  482. }
  483. $stmt->closeCursor();
  484. $stmt = null;
  485. ?>
  486. <select class="custom-select contribuye">
  487. <?php foreach($nivel_rs as $nivel){?>
  488. <option value="<?php echo $nivel["AtributoNivel_id"];?>"><?php echo $nivel["AtributoNivel_desc"];?></option>
  489. <?php } ?>
  490. </select>
  491. <div class="input-group-append">
  492. <button type="button" class="btn btn-outline-primary btn-sm d-none btn-agrega-atributo"><?php echo $ICO["mas"]; ?></button>
  493. </div>
  494. </div>
  495. </td>
  496. </tr>
  497. </tbody>
  498. </table>
  499. </div>
  500. </div>
  501. </div>
  502. </div>
  503. </div>
  504. <?php } ?>
  505. </div>
  506. <script src="../js/jquery.min.js"></script>
  507. <script src="../js/jquery-ui.js"></script>
  508. <script src="../js/datepicker-es.js"></script>
  509. <script src="../js/bootstrap/popper.min.js"></script>
  510. <script src="../js/bootstrap/bootstrap.min.js"></script>
  511. <script src="../js/sidebarmenu.js"></script>
  512. <script src="../js/toggle.js"></script>
  513. <script src="../js/datalist.js"></script>
  514. <script src="./js/materias.js"></script>
  515. <script>
  516. function showGrupo(){
  517. if($("#dlPlan ul li.selected").data("nivel") == 1){//licenciatura
  518. $("#gpo").parents(".form-group:first").hide();
  519. $("#gpo").val("");
  520. }else{
  521. $("#gpo").parents(".form-group:first").show();
  522. }
  523. }
  524. $(document).ready(function(){
  525. setDatalistFirst("#area");
  526. setDatalistFirst("#plan");
  527. loadSemestre(0);
  528. showGrupo();
  529. $('#tiposub').change(function(){
  530. /*if($(this).val() == "0"){
  531. $('#submateria').collapse('hide');
  532. }else{
  533. $('#submateria').collapse('show');
  534. }*/
  535. if($(this).prop("checked")){
  536. $('#submateria').collapse('show');
  537. }else{
  538. $('#submateria').collapse('hide');
  539. }
  540. });
  541. $(".modal-open").click(function(){
  542. $("#filter_desc").val("");
  543. $('#filter_area').get(0).selectedIndex = 0;
  544. $('#filter_plan').get(0).selectedIndex = 0;
  545. $("#table-result").find(".mat-desc").html("");
  546. $("#table-result").find(".mat-area").html("");
  547. $("#table-result").find(".mat-plan").html("");
  548. $("#table-result").find(".mat-sem").html("");
  549. $("#table-result").find(".mat-agrega button").addClass("d-none");
  550. var rows = $("#table-result > tr").length;//limpia tabla actual
  551. //borrar renglones extra (rows - result.length) pero dejar al menos 1
  552. while(rows > 1){
  553. $(".materia-row:last-child").remove();
  554. rows--;
  555. }
  556. $('#modal').modal("show");
  557. });
  558. $("#btn-busca").click(function(){
  559. var data = $("#forma_buscar").serialize();
  560. $.ajax({
  561. url: './action/materiarelacionada_find.php',
  562. type: 'POST',
  563. dataType: 'json',
  564. data: data,
  565. success: function(result) {
  566. if(result["error"]!= "" && result["error"] !== undefined){
  567. $('#modal').modal('hide');
  568. $("#errorBox").collapse('show');
  569. $("#errorBox_text").html(result["error"]);
  570. }else{
  571. //Crea tabla con resultado
  572. $("#table-result").find(".mat-desc").html("");
  573. $("#table-result").find(".mat-area").html("");
  574. $("#table-result").find(".mat-plan").html("");
  575. $("#table-result").find(".mat-sem").html("");
  576. $("#table-result").find(".mat-agrega button").addClass("d-none");
  577. var rows = $("#table-result > tr").length;//limpia tabla actual
  578. if(rows > result["materiaArr"].length){//sobran
  579. //borrar renglones extra (rows - result.length) pero dejar al menos 1
  580. while(rows > result["materiaArr"].length && rows > 1){
  581. $("#table-result .materia-row:last-child").remove();
  582. rows--;
  583. }
  584. }else{//faltan, clonar
  585. for(var i=rows; i<result["materiaArr"].length; i++){
  586. $("#table-result .materia-row:first-child").clone(true).appendTo("#table-result");
  587. }
  588. }
  589. if(result["materiaArr"].length != 0){//hay elementos?
  590. $("#table-result").children().each(function(index) {
  591. if(index < result["materiaArr"].length){//llenar info
  592. $(this).find(".mat-desc").html(result["materiaArr"][index]["Materia_desc"]);
  593. $(this).find(".mat-area").html(result["materiaArr"][index]["Area_desc"]);
  594. $(this).find(".mat-plan").html(result["materiaArr"][index]["PlanEstudio_desc"]);
  595. $(this).find(".mat-sem").html(result["materiaArr"][index]["Materia_semestre"]);
  596. $(this).find(".mat-agrega button").data("id", result["materiaArr"][index]["Materia_id"]);
  597. $(this).find(".mat-agrega button").data("text", result["materiaArr"][index]["Materia_desc"]+" [ "+result["materiaArr"][index]["PlanEstudio_desc"]+" ]");
  598. $(this).find(".mat-agrega button").removeClass("d-none");
  599. }
  600. });
  601. }
  602. }
  603. },
  604. error: function(jqXHR, textStatus, errorThrown ){
  605. $('#modal').modal('hide');
  606. $("#errorBox").collapse('show');
  607. $("#errorBox_text").html(errorThrown);
  608. }
  609. });//ajax
  610. });
  611. /*$("#plan").change(function(){
  612. loadSemestre();
  613. showGrupo();
  614. });*/
  615. $('#dlPlan ul li').click(function(){
  616. if(parseInt($(this).data("nivel")) == 1){
  617. $("#sem_texto").text("Semestres");
  618. }else{
  619. $("#sem_texto").text("Cuatrimestres");
  620. }
  621. loadSemestre();
  622. showGrupo();
  623. $("#atributos option").remove();
  624. });
  625. //----
  626. $(".modal-open-electiva").click(function(){
  627. $("#filter_desc").val("");
  628. $("#table-result-electiva").find(".mat-desc").html("");
  629. $("#table-result-electiva").find(".mat-agrega button").addClass("d-none");
  630. var rows = $("#table-result-electiva > tr").length;//limpia tabla actual
  631. //borrar renglones extra (rows - result.length) pero dejar al menos 1
  632. while(rows > 1){
  633. $(".materia-row:last-child").remove();
  634. rows--;
  635. }
  636. $('#modal-electiva').modal("show");
  637. });
  638. $("#btn-busca-electiva").click(function(){
  639. var data = $("#forma_buscar-electiva").serialize();
  640. $("#table-result-electiva tr").show();
  641. $.ajax({
  642. url: './action/electiva_find.php',
  643. type: 'POST',
  644. dataType: 'json',
  645. data: data,
  646. success: function(result) {
  647. if(result["error"]!= "" && result["error"] !== undefined){
  648. $('#modal-electiva').modal('hide');
  649. $("#errorBox").collapse('show');
  650. $("#errorBox_text").html(result["error"]);
  651. }else{
  652. //Crea tabla con resultado
  653. //$("#table-result").find("td").html("");//limpia tabla actual
  654. $("#table-result-electiva").find(".mat-desc").html("");
  655. $("#table-result-electiva").find(".mat-agrega button").addClass("d-none");
  656. var rows = $("#table-result-electiva > tr").length;//limpia tabla actual
  657. if(rows > result["electivaArr"].length){//sobran
  658. //borrar renglones extra (rows - result.length) pero dejar al menos 1
  659. while(rows > result["electivaArr"].length && rows > 1){
  660. $("#table-result-electiva .materia-row:last-child").remove();
  661. rows--;
  662. }
  663. }else{//faltan, clonar
  664. for(var i=rows; i<result["electivaArr"].length; i++){
  665. $("#table-result-electiva .materia-row:first-child").clone(true).appendTo("#table-result-electiva");
  666. }
  667. }
  668. if(result["electivaArr"].length != 0){//hay elementos?
  669. $("#table-result-electiva").children().each(function(index) {
  670. if(index < result["electivaArr"].length){//llenar info
  671. $(this).find(".mat-desc").html(result["electivaArr"][index]["Submateria_desc"]);
  672. $(this).find(".mat-agrega button").data("id", result["electivaArr"][index]["Submateria_id"]);
  673. $(this).find(".mat-agrega button").data("text", result["electivaArr"][index]["Submateria_desc"]);
  674. $(this).find(".mat-agrega button").removeClass("d-none");
  675. }
  676. });
  677. }/*else{
  678. $("#table-result").find(".mat-desc").html("No hay materias que coincidan con la búsqueda");
  679. $(this).find(".hora").html("");
  680. }*/
  681. }
  682. },
  683. error: function(jqXHR, textStatus, errorThrown ){
  684. $('#modal-electiva').modal('hide');
  685. $("#errorBox").collapse('show');
  686. $("#errorBox_text").html(errorThrown);
  687. }
  688. });//ajax
  689. });
  690. $(".btn-agrega-electiva").click(function(){
  691. var id = $(this).data("id");
  692. var text = $(this).data("text");
  693. var rows = $("#table-result-electiva > tr").length;//limpia tabla actual
  694. if($('#electiva option[value="' + id + '"]').length == 0){
  695. $("#electiva").append($("<option></option>").attr("value",id).text(text));
  696. }
  697. if(rows > 1)
  698. $(this).parents("tr").remove();
  699. else{
  700. $(this).parents("tr").hide();
  701. $("#filter_desc-electiva").val("");
  702. }
  703. });
  704. $(".btn-quita-electiva").click(function(){
  705. $("#electiva option:selected").remove();
  706. });
  707. // ------
  708. $(".modal-open-atributos").click(function(){
  709. var plan = $("#plan").val();
  710. $.ajax({
  711. url: './action/atributo_select.php',
  712. type: 'POST',
  713. dataType: 'json',
  714. data: {"plan":plan},
  715. success: function(result) {
  716. if(result["error"]!= "" && result["error"] !== undefined){
  717. $("#errorBox").collapse('show');
  718. $("#errorBox_text").html(result["error"]);
  719. }else{
  720. //Crea tabla con resultado
  721. //$("#table-result").find("td").html("");//limpia tabla actual
  722. if(result["atributoArr"].length != 0){//hay elementos?
  723. $("#sinatributos_block").hide();
  724. $("#conatributos_block").show();
  725. $("#table-result-atributos").find(".atributo-desc").html("");
  726. $("#table-result-atributos").find(".atributo-agrega button").addClass("d-none");
  727. var rows = $("#table-result-atributos > tr").length;//limpia tabla actual
  728. if(rows > result["atributoArr"].length){//sobran
  729. //borrar renglones extra (rows - result.length) pero dejar al menos 1
  730. while(rows > result["atributoArr"].length && rows > 1){
  731. $("#table-result-atributos .atributo-row:last-child").remove();
  732. rows--;
  733. }
  734. }else{//faltan, clonar
  735. for(var i=rows; i<result["atributoArr"].length; i++){
  736. $("#table-result-atributos .atributo-row:first-child").clone(true).appendTo("#table-result-atributos");
  737. }
  738. }
  739. $("#table-result-atributos").children().each(function(index) {
  740. if(index < result["atributoArr"].length){//llenar info
  741. $(this).find(".atributo-desc").html(result["atributoArr"][index]["id"]+" "+result["atributoArr"][index]["desc"]);
  742. $(this).find(".btn-agrega-atributo").data("id", result["atributoArr"][index]["id"]);
  743. $(this).find(".btn-agrega-atributo").data("text", result["atributoArr"][index]["desc"]);
  744. $(this).find(".btn-agrega-atributo").removeClass("d-none");
  745. }
  746. });
  747. }else{
  748. $("#sinatributos_block").show();
  749. $("#conatributos_block").hide();
  750. }
  751. $('#modal-atributos').modal("show");
  752. }
  753. },
  754. error: function(jqXHR, textStatus, errorThrown ){
  755. $("#errorBox").collapse('show');
  756. $("#errorBox_text").html(errorThrown);
  757. }
  758. });//ajax
  759. });
  760. $(".btn-agrega-atributo").click(function(){
  761. var id = $(this).data("id");
  762. var contribuye = $(this).parents(".input-group").find(".contribuye").val();
  763. var text = $(this).data("text");
  764. var rows = $("#table-result-atributos > tr").length;//limpia tabla actual
  765. var size = 60;
  766. if(text.length > size){
  767. text = text.substring(0,size)+"...";
  768. }
  769. text = "Atributo "+id+": "+text;
  770. var full_id = id+"|"+contribuye;
  771. if(!existeAtributo(id)){
  772. $("#atributos").append($("<option></option>").attr("value",full_id).text(text).data("id", id));
  773. }
  774. if(rows > 1)
  775. $(this).parents("tr").remove();
  776. else{
  777. $(this).parents("tr").hide();
  778. }
  779. });
  780. $(".btn-quita-atributos").click(function(){
  781. $("#atributos option:selected").remove();
  782. });
  783. });
  784. function existeAtributo(id){
  785. var existe =false;
  786. $("#atributos option").each(function(index) {
  787. if($(this).data("id") == id ){//llenar info
  788. existe = true;
  789. }
  790. });
  791. return existe;
  792. }
  793. </script>
  794. </body>
  795. </html>