pdf_syllabus.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. <?php
  2. /* AJAX
  3. * Genera syllabus en pdf
  4. * Recibe:
  5. * gop: ID de Grupo
  6. * mat: ID de materia
  7. * sub: ID de submateria o nada
  8. * Return:
  9. * imprime pdf
  10. */
  11. setlocale(LC_TIME, 'es_MX.UTF-8');
  12. require_once("../../include/nocache.php");
  13. require_once("../../include/constantes.php");
  14. require_once("../../include/bd_pdo.php");
  15. require_once("../../include/util.php");
  16. require_once("../../classes/ValidaSesion.php");
  17. include_once('../../include/xTemplate/xtemplate.class.php'); // including mpdf.php
  18. include_once('../../include/mpdf/autoload.php'); // including mpdf.php
  19. $pag = "../syllabus.php";
  20. //--- Objeto para validar usuario. El id de usuario lo lee desde sesión
  21. $objSesion = new ValidaSesion($pdo, 25, GEMA);
  22. if(!$objSesion->tieneAcceso()){
  23. header("Location: ".$pag."?error=3");
  24. exit();
  25. }
  26. unset($objValida);
  27. /*
  28. if(!isset($_POST["id"]) || !isset($_POST["fecha"])){
  29. header("Location: ".$pag."?error=0");
  30. exit();
  31. }
  32. $id = filter_input(INPUT_POST, "id", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  33. $fecha = trim(filter_input(INPUT_POST, "fecha", FILTER_SANITIZE_STRING,array('flags' => FILTER_FLAG_STRIP_LOW)));//limpia texto*/
  34. if(!isset($_POST["mat"], $_POST["gpo"])){
  35. header("Location: ".$pag."?error=0");
  36. exit();
  37. }
  38. $mat = filter_input(INPUT_POST, "mat", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  39. $gpo = filter_input(INPUT_POST, "gpo", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  40. $gpo_nom = trim(filter_input(INPUT_POST, "gpo_nom", FILTER_SANITIZE_STRING,array('flags' => FILTER_FLAG_STRIP_LOW)));//limpia texto
  41. $usr = $_SESSION["usuario_id"];
  42. $usr_nombre = $_SESSION["usuario_nombre"]." ".$_SESSION["usuario_apellidos"];
  43. if(isset($_POST["prof"]) && !empty($_POST["prof"])){
  44. $usr = filter_input(INPUT_POST, "prof", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  45. $stmt = $pdo->prepare('Select * from fs_usuario(:usr)');
  46. $stmt->bindParam(":usr", $usr);
  47. if(!$stmt->execute()){
  48. header("Location: ".$pag."?error=5");
  49. exit();
  50. }else{
  51. $usr_rs = $stmt->fetch();
  52. $usr_nombre = $usr_rs["Usuario_nombre"]." ".$usr_rs["Usuario_apellidos"];
  53. }
  54. $stmt->closeCursor();
  55. }
  56. if(isset($_POST["sub"]) && $_POST["sub"]!= ""){
  57. $sub = filter_input(INPUT_POST, "sub", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  58. $stmt = $pdo->prepare('Select * from fs_syllabus(:periodo, :prof, :mat, :gpo, :sub )');
  59. $stmt->bindParam(":sub", $sub);
  60. }else{
  61. $stmt = $pdo->prepare('Select * from fs_syllabus(:periodo, :prof, :mat, :gpo, NULL )');
  62. }
  63. $stmt->bindParam(":periodo", $_SESSION["periodo_id"]);
  64. $stmt->bindParam(":prof", $usr);
  65. $stmt->bindParam(":mat", $mat);
  66. $stmt->bindParam(":gpo", $gpo);
  67. if(!$stmt->execute()){
  68. header("Location: ".$pag."?error=3");
  69. //$errorDesc = "Error al cargar los datos del alumno";
  70. //print_r($stmt->errorInfo());
  71. exit();
  72. }
  73. $syllabus_rs = $stmt->fetch();
  74. $stmt->closeCursor();
  75. //print_r($syllabus_rs); exit;
  76. $stmt = $pdo->prepare('Select * from fs_periodo(:periodo, NULL, NULL, NULL )');
  77. $stmt->bindParam(":periodo", $_SESSION["periodo_id"]);
  78. if(!$stmt->execute()){
  79. header("Location: ".$pag."?error=3");
  80. //$errorDesc = "Error al cargar los datos del alumno";
  81. //print_r($stmt->errorInfo());
  82. exit();
  83. }
  84. $periodo_rs = $stmt->fetch();
  85. $stmt->closeCursor();
  86. if(isset($sub)){
  87. $stmt = $pdo->prepare('SELECT hg."Horario_hora", s."Salon_desc", s."Salon_desc_larga", d."Dia_desc"
  88. from fs_horariogrupo(:gpo, NULL, false) AS hg INNER JOIN "Dia" d ON hg."Dia_id" = d."Dia_id"
  89. INNER JOIN "Submateria_HorarioGrupo_Profesor" shgp ON hg."HorarioGrupo_id" = shgp."HorarioGrupo_id" AND shgp."Submateria_id" = :sub
  90. INNER JOIN "Salon" s ON shgp."Salon_id" = s."Salon_id" WHERE "Materia_id" = :mat ORDER BY d."Dia_id", hg."Horario_hora"' );
  91. $stmt->bindParam(":sub", $sub);
  92. }else{
  93. $stmt = $pdo->prepare('SELECT hg."Horario_hora", hg."Salon_desc", hg."Salon_desc_larga", d."Dia_desc"
  94. from fs_horariogrupo(:gpo, NULL, false) AS hg INNER JOIN "Dia" d ON hg."Dia_id" = d."Dia_id" WHERE "Materia_id" = :mat ORDER BY d."Dia_id", hg."Horario_hora"' );
  95. }
  96. $stmt->bindParam(":gpo", $gpo);
  97. $stmt->bindParam(":mat", $mat);
  98. if(!$stmt->execute()){
  99. header("Location: ".$pag."?error=3");
  100. // print_r($stmt->errorInfo());
  101. exit();
  102. }
  103. $horario_rs = $stmt->fetchAll();
  104. $stmt->closeCursor();
  105. //print_r($horario_rs); exit;
  106. //-----
  107. $defaultConfig = (new Mpdf\Config\ConfigVariables())->getDefaults();
  108. $fontDirs = $defaultConfig['fontDir'];
  109. $defaultFontConfig = (new Mpdf\Config\FontVariables())->getDefaults();
  110. $fontData = $defaultFontConfig['fontdata'];
  111. $mpdf = new \Mpdf\Mpdf([
  112. 'mode' => 'utf-8',
  113. 'format' => [215, 279],
  114. 'orientation' => 'P',
  115. 'margin_left' => 14,
  116. 'margin_right' => 14,
  117. 'margin_top' => 27,
  118. 'margin_bottom' => 27,
  119. 'fontDir' => array_merge($fontDirs, [
  120. __DIR__ . '/../../fonts/indivisaFont/ttf',
  121. ]),
  122. 'fontdata' => $fontData + [
  123. 'indivisa-display' => [
  124. 'R' => 'IndivisaDisplaySans-Regular.ttf',
  125. ],
  126. 'indivisa-title' => [
  127. 'R' => 'IndivisaDisplaySerif-RegularItalic.ttf',
  128. ],
  129. 'indivisa-text' => [
  130. 'R' => 'IndivisaTextSans-Regular.ttf',
  131. ]
  132. ],
  133. 'default_font' => 'indivisa-text',
  134. ]);
  135. //$mpdf->SetDisplayMode('fullpage');
  136. $stylesheet = "<style>";
  137. $stylesheet .= file_get_contents('../../css/indivisa.css'); // external css
  138. $stylesheet .= file_get_contents('../css/syllabus.css'); // external css
  139. $stylesheet .= "</style>";
  140. $xtpl = new XTemplate('../tpl/syllabus.tpl.html');
  141. $mat_nombre = isset($syllabus_rs["Submateria_desc"])?$syllabus_rs["Submateria_desc"]:$syllabus_rs["Materia_desc"];
  142. $xtpl->assign("MATERIA", $mat_nombre." ".$gpo_nom);
  143. $xtpl->assign("SEMESTRE", $syllabus_rs["Materia_semestre"]);
  144. $xtpl->assign("PERIODO", $periodo_rs["Periodo_desc"]);
  145. $xtpl->assign("PROFESOR", $usr_nombre);
  146. foreach($horario_rs as $h){
  147. $hora = substr($h["Horario_hora"], 0, 5);
  148. if(empty($h["Salon_desc"])){
  149. $salon = "Salón pendiente";
  150. }else{
  151. $salon = $h["Salon_desc"];
  152. if(!empty($h["Salon_desc_larga"])){
  153. $salon .=" (".$h["Salon_desc_larga"].")";
  154. }
  155. }
  156. $xtpl->assign("DIA", $h["Dia_desc"]);
  157. $xtpl->assign("HORA", $hora);
  158. $xtpl->assign("SALON", $salon);
  159. $xtpl->parse("main.content.contentfechas");
  160. }
  161. //---Atributos
  162. //Obtiene mapa
  163. $stmt = $pdo->prepare('select * from fs_atributoegreso_materia(:mat)');
  164. $stmt->bindParam(":mat", $mat);
  165. if(!$stmt->execute()){
  166. header("Location: ".$pag."?error=5");
  167. }else{
  168. $atributos_rs = $stmt->fetchAll();
  169. }
  170. //----
  171. $datos = array(
  172. array("titulo"=>"Información de la asignatura", "bd"=>"informacion", "subbloques"=>
  173. array(
  174. array("subtitulo"=>"Descripción","bd"=>"desc", "nobreak"=>false),
  175. array("subtitulo"=>"Objetivos","bd"=>"obj", "nobreak"=>false),
  176. array("subtitulo"=>"Capacidades y habilidades que desarrollar","bd"=>"capacidades", "nobreak"=>false),
  177. array("subtitulo"=>"Prerrequisitos","bd"=>"prerrequisitos", "nobreak"=>false),
  178. array("subtitulo"=>"Temario","bd"=>"temario", "nobreak"=>false),
  179. array("subtitulo"=>"Construcción de la calificación final","bd"=>"calificacion", "nobreak"=>true),
  180. array("subtitulo"=>"Fechas importantes","bd"=>"fechas", "nobreak"=>true),
  181. )
  182. ),
  183. array("titulo"=>"Lineamientos generales", "bd"=>"", "subbloques"=>
  184. array(
  185. array("subtitulo"=>"De la asistencia y puntualidad","bd"=>"asistencia", "nobreak"=>false),
  186. array("subtitulo"=>"Del comportamiento en clase","bd"=>"comportamiento", "nobreak"=>false),
  187. array("subtitulo"=>"De los exámenes","bd"=>"examenes", "nobreak"=>false),
  188. array("subtitulo"=>"De las tareas, prácticas y exposiciones","bd"=>"tareas", "nobreak"=>false),
  189. array("subtitulo"=>"Trabajos de investigación","bd"=>"investigacion", "nobreak"=>false),
  190. )
  191. ),
  192. array("titulo"=>"Bibliografía recomendada", "bd"=>"bibliografia", "subbloques"=>
  193. array(
  194. array("subtitulo"=>"","bd"=>"", "nobreak"=>true, "texto"=>"La/el docente que imparte la presente materia, en sus opiniones, posturas o críticas, citas o referencias de consulta, por la metodología didáctica que utiliza, por las herramientas pedagógicas de apoyo en la práctica educativa y, el desarrollo de los contenidos que integran el programa de la presente asignatura o por la implementación del modelo educativo de la Universidad, no tiene por objeto obstaculizar, restringir, impedir, menoscabar, anular o suprimir la orientación sexual, identidad o expresión de género de su alumnado; por ello, partiendo de su derecho de libertad de cátedra, enseña y promueve la construcción de conocimientos con objetividad e imparcialidad, sin censura ni restricciones, propiciando el debate y el análisis de los temas para enriquecer el aprendizaje, sin tener más límite que el respeto a los derechos del estudiantado."),
  195. )
  196. )
  197. );
  198. $atributos = false;
  199. foreach($datos as $bloque){
  200. $xtpl->assign("TITULO", $bloque["titulo"]);
  201. if($bloque["bd"]!= ""){
  202. $xtpl->assign("INFO", $syllabus_rs["Syllabus_".$bloque["bd"]]);
  203. $xtpl->parse("main.content.bloque.titulo.info");
  204. $xtpl->parse("main.content.bloque.titulo");
  205. $xtpl->parse("main.content.bloque");
  206. }
  207. if(!$atributos ){
  208. $atributos = true;
  209. if(count($atributos_rs) > 0){
  210. $html = "<ul>";
  211. foreach($atributos_rs as $atr){
  212. $html.="<li><b>Atributo {$atr["AtributoEgreso_id"]} nivel {$atr["AtributoNivel_desc"]}:</b> {$atr["AtributoEgreso_desc"]}</li>";
  213. }
  214. $html.="</ul>";
  215. $xtpl->assign("SUBTITULO", "Atributos de egreso");
  216. $xtpl->assign("INFO", $html);
  217. $xtpl->parse("main.content.bloque.subbloque");
  218. $xtpl->parse("main.content.bloque");
  219. }
  220. }
  221. foreach($bloque["subbloques"] as $subbloque){
  222. $xtpl->assign("SUBTITULO", $subbloque["subtitulo"]);
  223. if($subbloque["bd"]!= ""){
  224. $xtpl->assign("INFO", $syllabus_rs["Syllabus_".$subbloque["bd"]]);
  225. }else{
  226. $xtpl->assign("INFO", $subbloque["texto"]);
  227. }
  228. if($subbloque["nobreak"]) $xtpl->parse("main.content.bloque.subbloque_nobreak");
  229. else $xtpl->parse("main.content.bloque.subbloque");
  230. $xtpl->parse("main.content.bloque");
  231. }
  232. }
  233. $xtpl->parse("main.content");
  234. $xtpl->parse("main");
  235. /*echo $stylesheet;
  236. $xtpl->out("main"); exit;
  237. */
  238. $header = '<table style="width:100%"><tr>
  239. <td><img src="../../img/logopdf.png" width="40mm" class=""></td>
  240. <td align="right"><h1 class="titulo">SYLLABUS | FACULTAD DE INGENIERÍA</h1></td>
  241. </tr></table>';
  242. $mpdf->SHYlang = 'es';
  243. $mpdf-> SetTitle('Syllabus -' . $mat_nombre);
  244. $mpdf-> SetAuthor('Facultad de Ingeniería. © Universidad La Salle A.C. '.date("Y").' Todos los derechos Reservados.');
  245. $mpdf->SetHTMLHeader($header);//se pone como fondo
  246. $mpdf->SetHTMLFooter('<img src="../../img/footer_docs.png" >');//se pone como fondo
  247. $mpdf->WriteHTML($stylesheet);
  248. if(!isset($errorDesc))
  249. $mpdf->WriteHTML($xtpl->text("main"));
  250. else
  251. $mpdf->WriteHTML($errorDesc);
  252. $mpdf->Output("syllabus_".getIniciales($mat_nombre)."_".$gpo_nom.".pdf", 'I');
  253. ?>