pdf_alumnocardex.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <?php
  2. /* AJAX
  3. * Genera nombramientos en pdf
  4. * Recibe:
  5. * grupo
  6. * Return:
  7. * imprime pdf
  8. */
  9. setlocale(LC_TIME, 'es_MX.UTF-8');
  10. require_once("../../include/nocache.php");
  11. require_once("../../include/constantes.php");
  12. require_once("../../include/bd_pdo.php");
  13. require_once("../../include/util.php");
  14. require_once("../../classes/ValidaSesion.php");
  15. include_once('../../include/xTemplate/xtemplate.class.php'); // including mpdf.php
  16. include_once('../../include/mpdf/autoload.php'); // including mpdf.php
  17. $pag = "../reporte_alumnoscardex.php";
  18. //--- Objeto para validar usuario. El id de usuario lo lee desde sesión
  19. $objSesion = new ValidaSesion($pdo, array(102, 122), GEMA);
  20. if(!$objSesion->tieneAcceso()){
  21. header("Location: ".$pag."?error=3");
  22. exit();
  23. }
  24. unset($objValida);
  25. /*
  26. if(!isset($_POST["id"]) || !isset($_POST["fecha"])){
  27. header("Location: ".$pag."?error=0");
  28. exit();
  29. }
  30. $id = filter_input(INPUT_POST, "id", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  31. $fecha = trim(filter_input(INPUT_POST, "fecha", FILTER_SANITIZE_STRING,array('flags' => FILTER_FLAG_STRIP_LOW)));//limpia texto*/
  32. if(!isset($_GET["clave"])){
  33. header("Location: ".$pag."?error=0");
  34. exit();
  35. }
  36. $clave = filter_input(INPUT_GET, "clave", FILTER_SANITIZE_NUMBER_INT);//limpia texto
  37. //Obtiene horario del salon
  38. $stmt = $pdo->prepare('Select * from fs_alumno(NULL, :clave)');
  39. $stmt->bindParam(":clave", $clave);
  40. if(!$stmt->execute()){
  41. header("Location: materias.php?error=2");
  42. //$errorDesc = "Error al cargar los datos del alumno";
  43. //print_r($stmt->errorInfo());
  44. exit();
  45. }
  46. $alumno_rs = $stmt->fetch();
  47. $stmt->closeCursor();
  48. $stmt = $pdo->prepare('SELECT * FROM fs_alumnomaterias_cardex(:clave, :plan)');
  49. $stmt->bindParam(":clave", $clave);
  50. $stmt->bindParam(":plan", $alumno_rs["PlanEstudio_id"]);
  51. if(!$stmt->execute()){
  52. header("Location: ".$pag."?error=1");
  53. //$errorDesc = "Ocurrió un error al cargar las materias.";
  54. //print_r($stmt->errorInfo());
  55. exit();
  56. }
  57. $materias_rs = $stmt->fetchAll();
  58. $stmt->closeCursor();
  59. //formato al RS de materias
  60. $materiasArr = Array();
  61. $m = 0;
  62. $mat_last = -1;
  63. foreach($materias_rs as $mat){
  64. if($mat_last != $mat["Materia_id"]){
  65. if($mat_last != -1){
  66. $materiasArr[$m]["califArr"]=$califArr;
  67. $m++;
  68. }
  69. $mat_last = $mat["Materia_id"];
  70. $califArr = array();
  71. }
  72. $materiasArr[$m] = array("id" => $mat["Materia_id"], "desc" => $mat["Materia_desc"], "clave"=>$mat["Materia_clave"],
  73. "sem"=> $mat["Materia_semestre"], "califArr"=>array());
  74. if($mat["Calificacion_calif"] != null && $mat["Calificacion_calif"] != ""){
  75. $califArr[] = array("calif"=>$mat["Calificacion_calif"], "fecha"=>$mat["Calificacion_fecha"], "calif_tipo"=>$mat["TipoCalificacion_id"], "calif_tipo_desc"=>$mat["TipoCalificacion_desc"], "calif_tipo_corta"=>$mat["TipoCalificacion_desc_corta"],
  76. "revalidada"=>$mat["TipoCalificacion_esEquivalencia"], "reprobada"=>($mat["Calificacion_calif"] <=5)?true:false);
  77. }
  78. }
  79. if($mat_last != -1){
  80. $materiasArr[$m]["califArr"]=$califArr;
  81. }
  82. //-----
  83. $defaultConfig = (new Mpdf\Config\ConfigVariables())->getDefaults();
  84. $fontDirs = $defaultConfig['fontDir'];
  85. $defaultFontConfig = (new Mpdf\Config\FontVariables())->getDefaults();
  86. $fontData = $defaultFontConfig['fontdata'];
  87. $mpdf = new \Mpdf\Mpdf([
  88. 'mode' => 'utf-8',
  89. 'format' => [215, 279],
  90. 'orientation' => 'L',
  91. 'margin_top' => 7,
  92. 'margin_bottom' => 7,
  93. 'fontDir' => array_merge($fontDirs, [
  94. __DIR__ . '/../../fonts/indivisaFont/ttf',
  95. ]),
  96. 'fontdata' => $fontData + [
  97. 'indivisa-display' => [
  98. 'R' => 'IndivisaDisplaySans-Regular.ttf',
  99. ],
  100. 'indivisa-title' => [
  101. 'R' => 'IndivisaDisplaySerif-RegularItalic.ttf',
  102. ],
  103. 'indivisa-text' => [
  104. 'R' => 'IndivisaTextSans-Regular.ttf',
  105. ]
  106. ],
  107. 'default_font' => 'indivisa-text',
  108. ]);
  109. //$mpdf->SetDisplayMode('fullpage');
  110. $stylesheet = "<style>";
  111. $stylesheet .= file_get_contents('../../css/indivisa.css'); // external css
  112. $stylesheet .= file_get_contents('../css/alumnocardex.css'); // external css
  113. $stylesheet .= "</style>";
  114. $xtpl = new XTemplate('../tpl/alumnocardex.tpl.html');
  115. $xtpl->assign("CLAVE", $clave);
  116. $xtpl->assign("NOMBRE", $alumno_rs["Usuario_apellidos"]." ".$alumno_rs["Usuario_nombre"]);
  117. $xtpl->assign("CARRERA", $alumno_rs["Carrera_desc"]." ".$alumno_rs["PlanEstudio_desc"]);
  118. $xtpl->parse("main.top");
  119. $maxCol = 5;
  120. $semEnCol = 5;
  121. $sem = -1;
  122. if($alumno_rs["Nivel_id"] == 1)
  123. $xtpl->assign("SEMESTRE", "Semestre");
  124. else
  125. $xtpl->assign("SEMESTRE", "Cuatrimestre");
  126. $xtpl->assign("COL_SIZE", "50");
  127. foreach($materiasArr as $mat){
  128. if($sem != intval($mat["sem"])){
  129. if($sem != -1){
  130. $xtpl->parse("main.col.semestre");
  131. }
  132. $sem = intval($mat["sem"]);
  133. if(($sem)%$semEnCol == 0){
  134. $xtpl->parse("main.col");
  135. }
  136. $xtpl->assign("COLS", $maxCol+1);
  137. $xtpl->assign("NUM", $sem);
  138. }
  139. $xtpl->assign("MATERIA", $mat["desc"]);
  140. for($c=0; $c < $maxCol; $c++){
  141. if($c < count($mat["califArr"])){
  142. if($mat["califArr"][$c]["calif"] >0)
  143. $xtpl->assign("CALIF", $mat["califArr"][$c]["calif"]);
  144. else{
  145. if($mat["califArr"][$c]["calif_tipo"] == 2)//ordinario
  146. $xtpl->assign("CALIF", "SD");
  147. else
  148. $xtpl->assign("CALIF", "NP");
  149. }
  150. switch($mat["califArr"][$c]["calif_tipo"]){
  151. case 1: $xtpl->assign("COLOR", "calif-equivalencia"); break;
  152. case 2: $xtpl->assign("COLOR", ""); break;
  153. default: $xtpl->assign("COLOR", "calif-extraordinario"); break;
  154. }
  155. }else{//no hay mas intentos
  156. $xtpl->assign("CALIF", "&nbsp;");
  157. }
  158. $xtpl->parse("main.col.semestre.table_row.intento");
  159. }
  160. $xtpl->parse("main.col.semestre.table_row");
  161. }
  162. $xtpl->parse("main.col.semestre");
  163. $xtpl->parse("main.col");
  164. $xtpl->parse("main");
  165. /*echo $stylesheet;
  166. $xtpl->out("main");*/
  167. $mpdf->WriteHTML($stylesheet);
  168. if(!isset($errorDesc))
  169. $mpdf->WriteHTML($xtpl->text("main"));
  170. else
  171. $mpdf->WriteHTML($errorDesc);
  172. $mpdf->Output("cardexAlumno_".$clave.".pdf", 'I');
  173. ?>