| 1 | <? |
|---|
| 2 | // ************************************************************************************************************************************************* |
|---|
| 3 | // Aplicación WEB: ogAdmWebCon |
|---|
| 4 | // Autor: José Manuel Alonso (E.T.S.I.I.) Universidad de Sevilla |
|---|
| 5 | // Fecha Creación: Año 2009-2010 |
|---|
| 6 | // Fecha Última modificación: Noviembre-2005 |
|---|
| 7 | // Nombre del fichero: programacionesaulas.php |
|---|
| 8 | // Descripción : |
|---|
| 9 | // Visualiza las reservas pendientes, confirmadas, denegadas y fecha y hora de la reserva |
|---|
| 10 | // ************************************************************************************************************************************************* |
|---|
| 11 | include_once("../includes/ctrlacc.php"); |
|---|
| 12 | include_once("../clases/AdoPhp.php"); |
|---|
| 13 | include_once("../includes/constantes.php"); |
|---|
| 14 | include_once("../includes/CreaComando.php"); |
|---|
| 15 | include_once("../includes/HTMLCTEMULSELECT.php"); |
|---|
| 16 | include_once("../clases/ArbolVistaXML.php"); |
|---|
| 17 | include_once("../idiomas/php/".$idioma."/clases/Calendario_".$idioma.".php"); |
|---|
| 18 | include_once("../idiomas/php/".$idioma."/programacionesaulas_".$idioma.".php"); |
|---|
| 19 | //________________________________________________________________________________________________________ |
|---|
| 20 | $ambito=""; |
|---|
| 21 | $idambito=0; |
|---|
| 22 | $nombreambito=""; |
|---|
| 23 | $fechainicio=""; |
|---|
| 24 | $fechafin=""; |
|---|
| 25 | $estadoreserva=""; |
|---|
| 26 | $situacion=""; |
|---|
| 27 | |
|---|
| 28 | if (isset($_GET["ambito"])) $ambito=$_GET["ambito"]; |
|---|
| 29 | if (isset($_GET["idambito"])) $idambito=$_GET["idambito"]; |
|---|
| 30 | if (isset($_GET["nombreambito"])) $nombreambito=$_GET["nombreambito"]; |
|---|
| 31 | if (isset($_GET["tipocola"])) $tipocola=$_GET["tipocola"]; |
|---|
| 32 | |
|---|
| 33 | $cmd=CreaComando($cadenaconexion); |
|---|
| 34 | if (!$cmd) |
|---|
| 35 | Header('Location: '.$pagerror.'?herror=2'); // Error de conexión con servidor B.D. |
|---|
| 36 | //________________________________________________________________________________________________________ |
|---|
| 37 | // Criterios por defecto |
|---|
| 38 | if($ambito!="" && $idambito!="" && $nombreambito!="" && $tipocola!=""){ |
|---|
| 39 | $wfechainicio=mktime(0, 0, 0, date("m") , date("d"), date("Y")); // Reservas desde un mes anterior |
|---|
| 40 | $wfechafin=mktime(0, 0, 0, date("m")+6 , date("d"), date("Y")); |
|---|
| 41 | $fechainicio=date("d/m/Y",$wfechainicio); |
|---|
| 42 | $fechafin=date("d/m/Y ",$wfechafin); |
|---|
| 43 | // Tipos de reservas |
|---|
| 44 | switch($tipocola){ |
|---|
| 45 | case 0: |
|---|
| 46 | $westadoreserva[0]=$RESERVA_CONFIRMADA; |
|---|
| 47 | $westadoreserva[1]=$RESERVA_PENDIENTE; |
|---|
| 48 | $westadoreserva[2]=$RESERVA_DENEGADA; |
|---|
| 49 | |
|---|
| 50 | $estadoreserva=$RESERVA_CONFIRMADA."=".$LITRESERVA_CONFIRMADA.";"; |
|---|
| 51 | $estadoreserva.=$RESERVA_PENDIENTE."=".$LITRESERVA_PENDIENTE.";"; |
|---|
| 52 | $estadoreserva.=$RESERVA_DENEGADA."=".$LITRESERVA_DENEGADA.";"; |
|---|
| 53 | break; |
|---|
| 54 | case $RESERVA_CONFIRMADA: |
|---|
| 55 | $westadoreserva[0]=$RESERVA_CONFIRMADA; |
|---|
| 56 | $estadoreserva=$RESERVA_CONFIRMADA."=".$LITRESERVA_CONFIRMADA.";"; |
|---|
| 57 | break; |
|---|
| 58 | case $RESERVA_PENDIENTE: |
|---|
| 59 | $westadoreserva[0]=$RESERVA_PENDIENTE; |
|---|
| 60 | $estadoreserva=$RESERVA_PENDIENTE."=".$LITRESERVA_PENDIENTE.";"; |
|---|
| 61 | break; |
|---|
| 62 | case $RESERVA_DENEGADA: |
|---|
| 63 | $westadoreserva[0]=$RESERVA_DENEGADA; |
|---|
| 64 | $estadoreserva=$RESERVA_DENEGADA."=".$LITRESERVA_DENEGADA.";"; |
|---|
| 65 | break; |
|---|
| 66 | } |
|---|
| 67 | // Estados default |
|---|
| 68 | $wsituacion[0]=$RESERVA_PARADA; |
|---|
| 69 | $wsituacion[1]=$RESERVA_ACTIVA; |
|---|
| 70 | $situacion=$RESERVA_PARADA."=".$LITRESERVA_PARADA.";"; |
|---|
| 71 | $situacion.=$RESERVA_ACTIVA."=".$LITRESERVA_ACTIVA.";"; |
|---|
| 72 | } |
|---|
| 73 | //________________________________________________________________________________________________________ |
|---|
| 74 | // Recupera parametros del formulario |
|---|
| 75 | if (isset($_POST["ambito"])) $ambito=$_POST["ambito"]; |
|---|
| 76 | if (isset($_POST["idambito"])) $idambito=$_POST["idambito"]; |
|---|
| 77 | if (isset($_POST["nombreambito"])) $nombreambito=$_POST["nombreambito"]; |
|---|
| 78 | if (isset($_POST["fechainicio"])) $fechainicio=$_POST["fechainicio"]; |
|---|
| 79 | if (isset($_POST["fechafin"])) $fechafin=$_POST["fechafin"]; |
|---|
| 80 | |
|---|
| 81 | if (isset($_POST["estadoreserva"])) { |
|---|
| 82 | $estadoreserva=$_POST["estadoreserva"]; |
|---|
| 83 | $auxP=split(";",$estadoreserva); |
|---|
| 84 | $cont=0; |
|---|
| 85 | for ($i=0;$i<sizeof($auxP)-1;$i++){ |
|---|
| 86 | $dualparam=split("=",$auxP[$i]); |
|---|
| 87 | $westadoreserva[$cont++]=$dualparam[0]; |
|---|
| 88 | } |
|---|
| 89 | } |
|---|
| 90 | if (isset($_POST["situacion"])){ |
|---|
| 91 | $situacion=$_POST["situacion"]; |
|---|
| 92 | $auxP=split(";",$situacion); |
|---|
| 93 | $cont=0; |
|---|
| 94 | for ($i=0;$i<sizeof($auxP)-1;$i++){ |
|---|
| 95 | $dualparam=split("=",$auxP[$i]); |
|---|
| 96 | $wsituacion[$cont++]=$dualparam[0]; |
|---|
| 97 | } |
|---|
| 98 | } |
|---|
| 99 | //________________________________________________________________________________________________________ |
|---|
| 100 | ?> |
|---|
| 101 | <HTML> |
|---|
| 102 | <TITLE>Administración web de aulas</TITLE> |
|---|
| 103 | <HEAD> |
|---|
| 104 | <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> |
|---|
| 105 | <LINK rel="stylesheet" type="text/css" href="../estilos.css"> |
|---|
| 106 | <SCRIPT language="javascript" src="../clases/jscripts/ArbolVistaXML.js"></SCRIPT> |
|---|
| 107 | <SCRIPT language="javascript" src="../clases/jscripts/MenuContextual.js"></SCRIPT> |
|---|
| 108 | <SCRIPT language="javascript" src="../jscripts/constantes.js"></SCRIPT> |
|---|
| 109 | <SCRIPT language="javascript" src="../jscripts/comunes.js"></SCRIPT> |
|---|
| 110 | <SCRIPT language="javascript" src="../jscripts/programacionesaulas.js"></SCRIPT> |
|---|
| 111 | <? echo '<SCRIPT language="javascript" src="../idiomas/javascripts/'.$idioma.'/programacionesaulas_'.$idioma.'.js"></SCRIPT>'?> |
|---|
| 112 | <? echo '<SCRIPT language="javascript" src="../idiomas/javascripts/'.$idioma.'/comunes_'.$idioma.'.js"></SCRIPT>'?> |
|---|
| 113 | </HEAD> |
|---|
| 114 | <BODY> |
|---|
| 115 | <? |
|---|
| 116 | switch($ambito){ |
|---|
| 117 | case $AMBITO_CENTROS : |
|---|
| 118 | $urlimg='../images/iconos/centros.gif'; |
|---|
| 119 | $textambito=$TbMsg[12]; |
|---|
| 120 | break; |
|---|
| 121 | case $AMBITO_GRUPOSAULAS : |
|---|
| 122 | $urlimg='../images/iconos/carpeta.gif'; |
|---|
| 123 | $textambito=$TbMsg[13]; |
|---|
| 124 | break; |
|---|
| 125 | case $AMBITO_AULAS : |
|---|
| 126 | $urlimg='../images/iconos/aula.gif'; |
|---|
| 127 | $textambito=$TbMsg[14]; |
|---|
| 128 | break; |
|---|
| 129 | case $AMBITO_GRUPOSRESERVAS : |
|---|
| 130 | $urlimg='../images/iconos/carpeta.gif'; |
|---|
| 131 | $textambito=$TbMsg[30]; |
|---|
| 132 | break; |
|---|
| 133 | } |
|---|
| 134 | echo '<p align=center class=cabeceras><img src="../images/iconos/reservas.gif"> '.$TbMsg[0].' '; |
|---|
| 135 | echo '<FORM name="fdatos" action="programacionesaulas.php" method="post">'.chr(13); |
|---|
| 136 | // Campos ocultos |
|---|
| 137 | echo '<INPUT type=hidden name=ambito value="'.$ambito.'">'; |
|---|
| 138 | echo '<INPUT type=hidden name=idambito value="'.$idambito.'">'; |
|---|
| 139 | echo '<INPUT type=hidden name=nombreambito value="'.$nombreambito.'">'; |
|---|
| 140 | echo '<INPUT type=hidden name=estadoreserva value="'.$estadoreserva.'">'; |
|---|
| 141 | echo '<INPUT type=hidden name=situacion value="'.$situacion.'">'; |
|---|
| 142 | echo CriteriosBusquedas(); // Opciones de búsqueda |
|---|
| 143 | echo '</FORM>'.chr(13); |
|---|
| 144 | |
|---|
| 145 | echo '<DIV align=center >'; |
|---|
| 146 | echo '<span align=center class=subcabeceras><U>'.$TbMsg[11].':'.$textambito.'</U>, '.$nombreambito.'</span> <IMG src="'.$urlimg.'"></span></DIV></p>'; |
|---|
| 147 | //________________________________________________________________________________________________________ |
|---|
| 148 | // Proceso de selección de reservas |
|---|
| 149 | $ClausulaWhere=""; |
|---|
| 150 | //________________________________________________________________________________________________________ |
|---|
| 151 | // Cuestion identificador del ámbito |
|---|
| 152 | $WhereCentroAccion=""; |
|---|
| 153 | $WhereCentroAccion='reservas.idcentro='.$idcentro; |
|---|
| 154 | $ClausulaWhere.=" AND (".$WhereCentroAccion.")"; |
|---|
| 155 | |
|---|
| 156 | $cadenaaulas=""; |
|---|
| 157 | $cadenareservas=""; |
|---|
| 158 | $swa=false; // Para saber que ámbitos se han seleccionado |
|---|
| 159 | switch($ambito){ |
|---|
| 160 | case $AMBITO_CENTROS : |
|---|
| 161 | $cmd->texto="SELECT idcentro,nombrecentro FROM centros WHERE idcentro=".$idambito; |
|---|
| 162 | RecorreCentro($cmd); |
|---|
| 163 | break; |
|---|
| 164 | case $AMBITO_GRUPOSAULAS : |
|---|
| 165 | $cmd->texto="SELECT idgrupo,nombregrupo FROM grupos WHERE idgrupo=".$idambito." AND tipo=".$AMBITO_GRUPOSAULAS; |
|---|
| 166 | RecorreGruposAulas($cmd); |
|---|
| 167 | break; |
|---|
| 168 | case $AMBITO_AULAS : |
|---|
| 169 | $cmd->texto="SELECT idaula,nombreaula,horaresevfin FROM aulas WHERE idaula=".$idambito; |
|---|
| 170 | RecorreAulas($cmd); |
|---|
| 171 | break; |
|---|
| 172 | case $AMBITO_GRUPOSRESERVAS : |
|---|
| 173 | $swa=true; |
|---|
| 174 | if(!empty($idambito)){ |
|---|
| 175 | $cmd->texto="SELECT idgrupo FROM grupos WHERE idgrupo=".$idambito." AND tipo=".$AMBITO_GRUPOSRESERVAS; |
|---|
| 176 | RecorreGruposReservas($cmd); |
|---|
| 177 | } |
|---|
| 178 | else{ |
|---|
| 179 | $cmd->texto="SELECT idgrupo FROM grupos WHERE grupoid=0 AND tipo=".$AMBITO_GRUPOSRESERVAS; |
|---|
| 180 | RecorreGruposReservas($cmd); |
|---|
| 181 | $cmd->texto="SELECT idreserva FROM reservas WHERE grupoid=0"; |
|---|
| 182 | RecorreReservas($cmd); |
|---|
| 183 | } |
|---|
| 184 | break; |
|---|
| 185 | } |
|---|
| 186 | if(strlen($cadenaaulas)>0){ |
|---|
| 187 | $cadenaaulas=substr($cadenaaulas,0,strlen($cadenaaulas)-1); // Quita la coma |
|---|
| 188 | $ClausulaWhere.=" AND aulas.idaula IN(".$cadenaaulas.")"; |
|---|
| 189 | } |
|---|
| 190 | if(strlen($cadenareservas)>0){ |
|---|
| 191 | $cadenareservas=substr($cadenareservas,0,strlen($cadenareservas)-1); // Quita la coma |
|---|
| 192 | $ClausulaWhere.=" AND idreserva in(".$cadenareservas.")"; |
|---|
| 193 | } |
|---|
| 194 | //________________________________________________________________________________________________________ |
|---|
| 195 | // Cuestion estado de las reservas ( Confirmadas,Pendientes o Denegadas ) |
|---|
| 196 | $WhereEstadosReservas=""; |
|---|
| 197 | for($i=0;$i<sizeof($westadoreserva);$i++){ |
|---|
| 198 | if (isset($westadoreserva[$i])) |
|---|
| 199 | $WhereEstadosReservas.=" reservas.estado=".$westadoreserva[$i]." OR "; |
|---|
| 200 | } |
|---|
| 201 | if($WhereEstadosReservas!=""){ |
|---|
| 202 | $WhereEstadosReservas=substr($WhereEstadosReservas,0,strlen($WhereEstadosReservas)-3); |
|---|
| 203 | $ClausulaWhere.=" AND (".$WhereEstadosReservas.")"; |
|---|
| 204 | } |
|---|
| 205 | //________________________________________________________________________________________________________ |
|---|
| 206 | // Cuestion situación de la programación |
|---|
| 207 | $WhereSituaciones=""; |
|---|
| 208 | for($i=0;$i<sizeof($wsituacion);$i++){ |
|---|
| 209 | if (isset($wsituacion[$i])) |
|---|
| 210 | $WhereSituaciones.=" programaciones.suspendida=".$wsituacion[$i]." OR "; |
|---|
| 211 | } |
|---|
| 212 | if($WhereSituaciones!=""){ |
|---|
| 213 | $WhereSituaciones=substr($WhereSituaciones,0,strlen($WhereSituaciones)-3); |
|---|
| 214 | $ClausulaWhere.=" AND (".$WhereSituaciones.")"; |
|---|
| 215 | } |
|---|
| 216 | //________________________________________________________________________________________________________ |
|---|
| 217 | // Cuestion de fechas |
|---|
| 218 | $calendario=new Calendario("tabla_reservas"); |
|---|
| 219 | |
|---|
| 220 | if(empty($fechainicio)) $fechainicio=date("d/m/Y",mktime(0, 0, 0, date("m") , date("d"), date("Y"))); |
|---|
| 221 | if(empty($fechafin)) $fechafin=date("d/m/Y",mktime(0, 0, 0, date("m")+1 , date("d"), date("Y"))); |
|---|
| 222 | |
|---|
| 223 | $sumahoras=0; |
|---|
| 224 | $JDif=0; |
|---|
| 225 | $TBfechas=""; |
|---|
| 226 | $TOTfechas=""; |
|---|
| 227 | $cadenaXML=ProcesoAnual($fechainicio,$fechafin,$swa); |
|---|
| 228 | // Creación del árbol |
|---|
| 229 | $baseurlimg="../images/tsignos"; // Url de las imágenes de signo |
|---|
| 230 | $clasedefault="tabla_listados_sin"; |
|---|
| 231 | $titulotabla=$TbMsg[0]; |
|---|
| 232 | $arbol=new ArbolVistaXml($cadenaXML,0,$baseurlimg,$clasedefault,1,20,270,2,$titulotabla); |
|---|
| 233 | $salidaHTML=$arbol->CreaArbolVistaXml(); // Muestra árbol |
|---|
| 234 | echo "<BR>"; |
|---|
| 235 | echo "<DIV align=center width=100%>"; |
|---|
| 236 | echo " <TABLE align=center width=100%>"; |
|---|
| 237 | echo " <TR><TD>"; |
|---|
| 238 | echo urldecode($salidaHTML); |
|---|
| 239 | echo " </TD></TR><TABLE></DIV>"; |
|---|
| 240 | ?> |
|---|
| 241 | </BODY> |
|---|
| 242 | </HTML> |
|---|
| 243 | <? |
|---|
| 244 | // ************************************************************************************************************************************************* |
|---|
| 245 | function ProcesoAnual($fechainicio,$fechafin,$swa){ |
|---|
| 246 | global $EJECUCION_RESERVA; |
|---|
| 247 | global $calendario; |
|---|
| 248 | global $cmd; |
|---|
| 249 | global $ClausulaWhere; |
|---|
| 250 | global $sumahoras; |
|---|
| 251 | global $TbMsg; |
|---|
| 252 | global $TOTfechas; |
|---|
| 253 | global $TBfechas; |
|---|
| 254 | global $JDif; |
|---|
| 255 | |
|---|
| 256 | list($sdia,$smes,$sanno)=split("/",$fechainicio); |
|---|
| 257 | $dia_i=(int)$sdia; |
|---|
| 258 | $mes_i=(int)$smes; |
|---|
| 259 | $anno_i=(int)$sanno; |
|---|
| 260 | |
|---|
| 261 | list($sdia,$smes,$sanno)=split("/",$fechafin); |
|---|
| 262 | $dia_f=(int)$sdia; |
|---|
| 263 | $mes_f=(int)$smes; |
|---|
| 264 | $anno_f=(int)$sanno; |
|---|
| 265 | |
|---|
| 266 | $udm=$calendario->dias_meses[(int)$mes_f]; // Último día del mes |
|---|
| 267 | if($calendario->bisiesto($anno_f) && $mes_f==2) $udm++; |
|---|
| 268 | |
|---|
| 269 | $JDif=$calendario->juliana("1/".$mes_i."/".$anno_i); // calcula valor de resta para indices de fechas en tabla de memoria |
|---|
| 270 | $JDesde=0; |
|---|
| 271 | $JHasta=$calendario->juliana($udm."/".$mes_f."/".$anno_f)-$JDif; |
|---|
| 272 | $TOTfechas=""; // tabla en memoria para acumulado de horas por fecha |
|---|
| 273 | $TBfechas=""; // tabla en memoria para acumulado de horas por fecha |
|---|
| 274 | |
|---|
| 275 | $cmd->texto="SELECT SUM(horaresevfin - horaresevini) as sumahoras FROM aulas"; |
|---|
| 276 | $rs=new Recordset; |
|---|
| 277 | $rs->Comando=&$cmd; |
|---|
| 278 | if (!$rs->Abrir()) $sumahoras=0; // Error al abrir recordset |
|---|
| 279 | if(!$rs->EOF){ |
|---|
| 280 | $sumahoras=$rs->campos["sumahoras"]*60; |
|---|
| 281 | } |
|---|
| 282 | |
|---|
| 283 | //Recorre de fecha inicio a fecha fin |
|---|
| 284 | $anno_c=$anno_i; |
|---|
| 285 | $mes_c=$mes_i; |
|---|
| 286 | |
|---|
| 287 | $cadenaXML=""; |
|---|
| 288 | |
|---|
| 289 | // Calcula el rango de meses dependiendo del intervalo de fechas solicitado |
|---|
| 290 | while($anno_c<=$anno_f){ |
|---|
| 291 | if($anno_c==$anno_i){ |
|---|
| 292 | $mes_c=$mes_i; |
|---|
| 293 | if($anno_f>$anno_c) |
|---|
| 294 | $mes_t=12; |
|---|
| 295 | else |
|---|
| 296 | $mes_t=$mes_f; |
|---|
| 297 | } |
|---|
| 298 | else{ |
|---|
| 299 | if($anno_c>$anno_i){ |
|---|
| 300 | if($anno_c==$anno_f){ |
|---|
| 301 | $mes_c=1; |
|---|
| 302 | $mes_t=$mes_f; |
|---|
| 303 | } |
|---|
| 304 | else{ |
|---|
| 305 | $mes_c=1; |
|---|
| 306 | $mes_t=12; |
|---|
| 307 | } |
|---|
| 308 | } |
|---|
| 309 | } |
|---|
| 310 | $HEXanno=$calendario->numero_annos[$anno_c-2003][1]; // Primera referencia: 2004 |
|---|
| 311 | $HEXmeses=0; |
|---|
| 312 | $mes_desde=$mes_c; |
|---|
| 313 | $mes_hasta=$mes_t; |
|---|
| 314 | while($mes_c<=$mes_t){ |
|---|
| 315 | $HEXmeses=$HEXmeses | $calendario->nombre_mes[(int)$mes_c][1]; |
|---|
| 316 | $mes_c++; |
|---|
| 317 | } |
|---|
| 318 | // Cadena SQL para seleccionar reservas |
|---|
| 319 | $cmd->texto="SELECT programaciones.idprogramacion, programaciones.nombrebloque,programaciones.annos, programaciones.meses, programaciones.diario, programaciones.dias, programaciones.semanas, programaciones.horasini, programaciones.ampmini, programaciones.minutosini, programaciones.horasfin, programaciones.ampmfin, programaciones.minutosfin,"; |
|---|
| 320 | $cmd->texto.="trabajos.idtrabajo,tareas.idtarea,trabajos.descripcion AS nombretrabajo,tareas.descripcion AS nombretarea,"; |
|---|
| 321 | $cmd->texto.="reservas.idreserva,reservas.descripcion,reservas.solicitante,reservas.email,reservas.estado,reservas.idaula,"; |
|---|
| 322 | $cmd->texto.="aulas.horaresevfin ,aulas.horaresevini ,aulas.nombreaula as nombreaula,imagenes.idimagen ,imagenes.descripcion as nombreimagen"; |
|---|
| 323 | $cmd->texto.=" FROM reservas"; |
|---|
| 324 | $cmd->texto.=" INNER JOIN programaciones ON reservas.idreserva = programaciones.identificador"; |
|---|
| 325 | $cmd->texto.=" INNER JOIN aulas ON reservas.idaula = aulas.idaula"; |
|---|
| 326 | $cmd->texto.=" LEFT OUTER JOIN imagenes ON reservas.idimagen = imagenes.idimagen"; |
|---|
| 327 | $cmd->texto.=" LEFT OUTER JOIN tareas ON reservas.idtarea = tareas.idtarea"; |
|---|
| 328 | $cmd->texto.=" LEFT OUTER JOIN trabajos ON reservas.idtrabajo = trabajos.idtrabajo"; |
|---|
| 329 | $cmd->texto.=" WHERE (programaciones.tipoaccion = ".$EJECUCION_RESERVA.") ".$ClausulaWhere ; |
|---|
| 330 | $cmd->texto.=" AND (programaciones.annos & ".$HEXanno."<>0)"; |
|---|
| 331 | $cmd->texto.=" AND (programaciones.meses & ".$HEXmeses."<>0)" ; |
|---|
| 332 | $cmd->texto.=" ORDER BY programaciones.annos,programaciones.meses,"; |
|---|
| 333 | if($swa) |
|---|
| 334 | $cmd->texto.="programaciones.ampmini,programaciones.horasini,programaciones.minutosini"; |
|---|
| 335 | else |
|---|
| 336 | $cmd->texto.="aulas.idaula,programaciones.ampmini,programaciones.horasini,programaciones.minutosini"; |
|---|
| 337 | |
|---|
| 338 | $AuxcadenaXML=ListaReservas($cmd,$anno_c,$mes_desde,$mes_hasta,$dia_i,$dia_f,$mes_i,$mes_f,$anno_i,$anno_f,$swa); |
|---|
| 339 | |
|---|
| 340 | $cadenaXML.='<TBANNO '; |
|---|
| 341 | // Atributos |
|---|
| 342 | $cadenaXML.=' imagenodo="../images/iconos/reloj.gif"'; |
|---|
| 343 | $cadenaXML.=' clickimg="AnnoReserva('.$anno_c.');"'; |
|---|
| 344 | $cadenaXML.=' infonodo="%3Cb%3E '.$TbMsg[15].': %3C/b%3E'.$anno_c.'"'; |
|---|
| 345 | $cadenaXML.=' nodoid=anno-'.$anno_c; |
|---|
| 346 | $cadenaXML.='>'; |
|---|
| 347 | $cadenaXML.='<ANNO '; |
|---|
| 348 | // Atributos |
|---|
| 349 | $cadenaXML.=' imagenodo="../images/iconos/nada.gif"'; |
|---|
| 350 | //___________________________________________________________________________ |
|---|
| 351 | $HTMLannos="<TABLE><TR>"; |
|---|
| 352 | for ($i=$mes_desde;$i<=$mes_hasta;$i++){ |
|---|
| 353 | if($i%7==0) $HTMLannos.="</TR><TR>"; |
|---|
| 354 | $HTMLannos.='<TD style="BACKGROUND-COLOR:#FFFFFF" valign=top>'; |
|---|
| 355 | $HTMLannos.=$calendario->JMesAnno($i,$anno_c,$JDif,$TOTfechas,$sumahoras); |
|---|
| 356 | $HTMLannos.='</TD>'; |
|---|
| 357 | } |
|---|
| 358 | $HTMLannos.="</TR></TABLE>"; |
|---|
| 359 | //___________________________________________________________________________ |
|---|
| 360 | $cadenaXML.=' infonodo='.urlencode($HTMLannos); |
|---|
| 361 | $cadenaXML.=' nodoid=tablameses-'.$anno_c; |
|---|
| 362 | $cadenaXML.=' fondonodo='."#FFFFFF"; |
|---|
| 363 | $cadenaXML.='>'; |
|---|
| 364 | $cadenaXML.='</ANNO> '; |
|---|
| 365 | $cadenaXML.=$AuxcadenaXML; |
|---|
| 366 | $cadenaXML.='</TBANNO> '; |
|---|
| 367 | |
|---|
| 368 | $anno_c++; |
|---|
| 369 | } |
|---|
| 370 | return($cadenaXML); |
|---|
| 371 | } |
|---|
| 372 | //________________________________________________________________________________________________________ |
|---|
| 373 | function CriteriosBusquedas(){ |
|---|
| 374 | global $idcentro; |
|---|
| 375 | global $TbMsg; |
|---|
| 376 | |
|---|
| 377 | global $RESERVA_CONFIRMADA; |
|---|
| 378 | global $RESERVA_PENDIENTE; |
|---|
| 379 | global $RESERVA_DENEGADA; |
|---|
| 380 | global $LITRESERVA_CONFIRMADA; |
|---|
| 381 | global $LITRESERVA_PENDIENTE; |
|---|
| 382 | global $LITRESERVA_DENEGADA; |
|---|
| 383 | |
|---|
| 384 | global $RESERVA_PARADA; // reserva momentanemente parada |
|---|
| 385 | global $RESERVA_ACTIVA; // Reserva activa |
|---|
| 386 | global $LITRESERVA_PARADA; |
|---|
| 387 | global $LITRESERVA_ACTIVA; |
|---|
| 388 | |
|---|
| 389 | global $fechainicio; |
|---|
| 390 | global $fechafin; |
|---|
| 391 | |
|---|
| 392 | global $westadoreserva; |
|---|
| 393 | global $wsituacion; |
|---|
| 394 | |
|---|
| 395 | $HTMLCriterios=""; |
|---|
| 396 | $HTMLCriterios.='<TABLE class=tabla_busquedas align=center border="0">'.chr(13); |
|---|
| 397 | $HTMLCriterios.='<TR HEIGHT=30>'.chr(13); |
|---|
| 398 | $HTMLCriterios.='<TD colspan=4 align="center" >'.chr(13); |
|---|
| 399 | $HTMLCriterios.='<SPAN align=center style="FONT-FAMILY: Verdana, Arial, Helvetica, sans-serif; FONT-SIZE: 11px;COLOR:#5a86b5;FONT-WEIGHT: 700;">_______________ '.$TbMsg[1].' _______________</SPAN>'.chr(13); |
|---|
| 400 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 401 | $HTMLCriterios.='</TD>'.chr(13); |
|---|
| 402 | |
|---|
| 403 | // Desplegable con los tipos de reservas |
|---|
| 404 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 405 | $HTMLCriterios.='<TD>'.chr(13); |
|---|
| 406 | $HTMLCriterios.='<TABLE class=tabla_standar align=center border="0">'.chr(13); |
|---|
| 407 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 408 | $HTMLCriterios.=' <TH align=center> '.$TbMsg[2].' </TH>'.chr(13); |
|---|
| 409 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 410 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 411 | $parametros=$RESERVA_CONFIRMADA."=".$LITRESERVA_CONFIRMADA.chr(13); |
|---|
| 412 | $parametros.=$RESERVA_PENDIENTE."=".$LITRESERVA_PENDIENTE.chr(13); |
|---|
| 413 | $parametros.=$RESERVA_DENEGADA."=".$LITRESERVA_DENEGADA; |
|---|
| 414 | $HTMLCriterios.='<TD colspan=3>'.HTMLCTEMULSELECT($parametros,"westadoreserva",$westadoreserva,"estilodesple","chgdesplereservas",100,3).'</TD>'; |
|---|
| 415 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 416 | $HTMLCriterios.='</TABLE>'.chr(13); |
|---|
| 417 | $HTMLCriterios.='</TD>'.chr(13); |
|---|
| 418 | // Desplegable con los distintos situacion |
|---|
| 419 | $HTMLCriterios.='<TD>'.chr(13); |
|---|
| 420 | $HTMLCriterios.='<TABLE class=tabla_standar align=center border="0">'.chr(13); |
|---|
| 421 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 422 | $HTMLCriterios.=' <TH align=center> '.$TbMsg[4].' </TH>'.chr(13); |
|---|
| 423 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 424 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 425 | $parametros=$RESERVA_PARADA."=".$LITRESERVA_PARADA.chr(13); |
|---|
| 426 | $parametros.=$RESERVA_ACTIVA."=".$LITRESERVA_ACTIVA; |
|---|
| 427 | $HTMLCriterios.='<TD colspan=3>'.HTMLCTEMULSELECT($parametros,"wsituacion",$wsituacion,"estilodesple","chgdesplesituacion",100,3).'</TD>'; |
|---|
| 428 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 429 | $HTMLCriterios.='</TABLE>'.chr(13); |
|---|
| 430 | $HTMLCriterios.='</TD>'.chr(13); |
|---|
| 431 | |
|---|
| 432 | // Fechas |
|---|
| 433 | $HTMLCriterios.='<TD COLSPAN=2>'.chr(13); |
|---|
| 434 | $HTMLCriterios.='<TABLE WIDTH=100% class=tabla_standar align=center border="0">'.chr(13); |
|---|
| 435 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 436 | $HTMLCriterios.='<TH> '.$TbMsg[7].': </TH>'.chr(13); |
|---|
| 437 | $HTMLCriterios.='<TD><INPUT class="cajatexto" onclick="vertabla_calendario(this)" style="WIDTH:80" name="fechainicio" value="'.$fechainicio.'"></TD>'.chr(13); |
|---|
| 438 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 439 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 440 | $HTMLCriterios.='<TH align=right> '.$TbMsg[8].': </TH>'.chr(13); |
|---|
| 441 | $HTMLCriterios.='<TD> <INPUT class="cajatexto" onclick="vertabla_calendario(this)" style="WIDTH:80" name="fechafin" value="'.$fechafin.'"></TD>'.chr(13); |
|---|
| 442 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 443 | $HTMLCriterios.='</TABLE>'.chr(13); |
|---|
| 444 | $HTMLCriterios.='</TD>'.chr(13); |
|---|
| 445 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 446 | |
|---|
| 447 | $HTMLCriterios.='<TR height=5>'.chr(13); |
|---|
| 448 | $HTMLCriterios.='<TD colspan=4 align="center" >'.chr(13); |
|---|
| 449 | $HTMLCriterios.='<SPAN style="FONT-FAMILY: Verdana, Arial, Helvetica, sans-serif; FONT-SIZE: 11px;COLOR:#5a86b5;FONT-WEIGHT: 700;">__________________________________________________</SPAN>'.chr(13); |
|---|
| 450 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 451 | |
|---|
| 452 | // Lupa |
|---|
| 453 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 454 | $HTMLCriterios.='<TD COLSPAN=4>'.chr(13); |
|---|
| 455 | $HTMLCriterios.='<TABLE class=tabla_busquedas align=center border="0">'.chr(13); |
|---|
| 456 | $HTMLCriterios.='<TR>'.chr(13); |
|---|
| 457 | $HTMLCriterios.='<TD>'; |
|---|
| 458 | |
|---|
| 459 | $HTMLCriterios.='<IMG src="../images/iconos/busquedas.gif" onclick="javascript:fdatos.submit()" style="cursor:hand" alt="Buscar">'; |
|---|
| 460 | $HTMLCriterios.='</TD>'; |
|---|
| 461 | $HTMLCriterios.='<TD>'; |
|---|
| 462 | $HTMLCriterios.='</TD>'.chr(13); |
|---|
| 463 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 464 | $HTMLCriterios.='</TABLE>'; |
|---|
| 465 | $HTMLCriterios.='</TD>'.chr(13); |
|---|
| 466 | $HTMLCriterios.='</TR>'.chr(13); |
|---|
| 467 | $HTMLCriterios.='</TABLE>'; |
|---|
| 468 | return($HTMLCriterios); |
|---|
| 469 | } |
|---|
| 470 | //________________________________________________________________________________________________________ |
|---|
| 471 | function ListaReservas($cmd,$anno_c,$mes_desde,$mes_hasta,$dia_i,$dia_f,$mes_i,$mes_f,$anno_i,$anno_f,$swa){ |
|---|
| 472 | global $calendario; |
|---|
| 473 | global $JDif; |
|---|
| 474 | global $TBfechas; |
|---|
| 475 | global $TOTfechas; |
|---|
| 476 | global $sumahoras; |
|---|
| 477 | global $TbMsg; |
|---|
| 478 | |
|---|
| 479 | $cadenaXML=""; |
|---|
| 480 | |
|---|
| 481 | $udm=$calendario->dias_meses[(int)$mes_hasta]; // Último día del mes |
|---|
| 482 | if($calendario->bisiesto($anno_f) && $mes_hasta==2) $udm++; |
|---|
| 483 | $fechaminima=mktime(0, 0, 0, $mes_i, 1, $anno_i); |
|---|
| 484 | $fechamaxima=mktime(0, 0, 0, $mes_f,$udm, $anno_f); |
|---|
| 485 | |
|---|
| 486 | $rs=new Recordset; |
|---|
| 487 | $rs->Comando=&$cmd; |
|---|
| 488 | if (!$rs->Abrir()) return; // Error al abrir recordset |
|---|
| 489 | $rs->Primero(); |
|---|
| 490 | $gidaula=0; |
|---|
| 491 | |
|---|
| 492 | if($swa) |
|---|
| 493 | $wsumahoras=$sumahoras; |
|---|
| 494 | |
|---|
| 495 | // Recorre reservas |
|---|
| 496 | while (!$rs->EOF){ |
|---|
| 497 | if(!$swa){ |
|---|
| 498 | if($gidaula!=$rs->campos["idaula"]){ |
|---|
| 499 | $wsumahoras=($rs->campos["horaresevfin"]-$rs->campos["horaresevini"])*60;; |
|---|
| 500 | if($gidaula>0) |
|---|
| 501 | $cadenaXML.='</AULA>'; |
|---|
| 502 | $gidaula=$rs->campos["idaula"]; |
|---|
| 503 | $nombreaula=$rs->campos["nombreaula"]; |
|---|
| 504 | $cadenaXML.='<AULA '; |
|---|
| 505 | // Atributos |
|---|
| 506 | $cadenaXML.=' imagenodo="../images/iconos/aula.gif"'; |
|---|
| 507 | $cadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[24].':%3C/b%3E '.$rs->campos["nombreaula"].'"';; |
|---|
| 508 | $cadenaXML.=' nodoid=aula-'.$rs->campos["idaula"]; |
|---|
| 509 | $cadenaXML.=' colornodo='."#000000"; |
|---|
| 510 | $cadenaXML.=' fondonodo='."#B5DAAD;"; |
|---|
| 511 | $cadenaXML.='>'; |
|---|
| 512 | } |
|---|
| 513 | } |
|---|
| 514 | $swr=false; // detecta si la reserva es válida |
|---|
| 515 | $TBfechas=""; // tabla en memoria para acumulado de horas por fecha de cada reserva |
|---|
| 516 | $cf=$calendario->Fechas($anno_c,$mes_desde,$mes_hasta,$rs->campos["meses"],$rs->campos["diario"],$rs->campos["dias"],$rs->campos["semanas"]); |
|---|
| 517 | $fechas_reservas=split(";",$cf); |
|---|
| 518 | for ($i=0;$i<sizeof($fechas_reservas)-1;$i++){ |
|---|
| 519 | list($auxdia,$auxmes,$auxanno)=split("/",$fechas_reservas[$i]); |
|---|
| 520 | $auxfecha=mktime(0, 0, 0, $auxmes,$auxdia, $auxanno); |
|---|
| 521 | if($auxfecha>=$fechaminima && $auxfecha<=$fechamaxima){ |
|---|
| 522 | $swr=true; |
|---|
| 523 | $Jreserva=$calendario->juliana($fechas_reservas[$i]); |
|---|
| 524 | $idx=$Jreserva-$JDif; |
|---|
| 525 | // Cálculo de los minutos |
|---|
| 526 | $sOcupacion=CalculaMinutos($rs); |
|---|
| 527 | if (!isset($TBfechas[$idx])) $TBfechas[$idx]=0; |
|---|
| 528 | if (!isset($TOTfechas[$idx])) $TOTfechas[$idx]=0; |
|---|
| 529 | $TBfechas[$idx]+=$sOcupacion; |
|---|
| 530 | $TOTfechas[$idx]+=$sOcupacion; |
|---|
| 531 | } |
|---|
| 532 | } |
|---|
| 533 | if($swr) |
|---|
| 534 | $cadenaXML.=TomaReserva($rs,$mes_desde,$mes_hasta,$anno_c,$wsumahoras); |
|---|
| 535 | $rs->Siguiente(); |
|---|
| 536 | } |
|---|
| 537 | if(!$swa){ |
|---|
| 538 | if($gidaula>0) |
|---|
| 539 | $cadenaXML.='</AULA>'; |
|---|
| 540 | } |
|---|
| 541 | $rs->Cerrar(); |
|---|
| 542 | return($cadenaXML); |
|---|
| 543 | } |
|---|
| 544 | //________________________________________________________________________________________________________ |
|---|
| 545 | function TomaReserva($rs,$mes_desde,$mes_hasta,$anno_c,$wsumahoras){ |
|---|
| 546 | global $TbMsg; |
|---|
| 547 | global $calendario; |
|---|
| 548 | global $RESERVA_CONFIRMADA; |
|---|
| 549 | global $RESERVA_PENDIENTE; |
|---|
| 550 | global $RESERVA_DENEGADA; |
|---|
| 551 | global $EJECUCION_RESERVA; |
|---|
| 552 | global $TBfechas; |
|---|
| 553 | global $sumahoras; |
|---|
| 554 | global $JDif; |
|---|
| 555 | |
|---|
| 556 | $AuxcadenaXML=""; |
|---|
| 557 | |
|---|
| 558 | $tbimg[$RESERVA_CONFIRMADA]='../images/iconos/confirmadas.gif'; |
|---|
| 559 | $tbimg[$RESERVA_PENDIENTE]='../images/iconos/pendientes.gif'; |
|---|
| 560 | $tbimg[$RESERVA_DENEGADA]='../images/iconos/denegadas.gif'; |
|---|
| 561 | |
|---|
| 562 | $tbampm[0]="a.m."; |
|---|
| 563 | $tbampm[1]="p.m."; |
|---|
| 564 | |
|---|
| 565 | // Descripción de la reserva |
|---|
| 566 | $AuxcadenaXML.='<RESERVAS '; |
|---|
| 567 | // Atributos |
|---|
| 568 | $AuxcadenaXML.=' imagenodo="../images/iconos/reservas.gif"'; |
|---|
| 569 | |
|---|
| 570 | // Construye tabla de ocupación |
|---|
| 571 | |
|---|
| 572 | $AuxcadenaXML.=' infonodo="%3CIMG border=0 src='.$tbimg[$rs->campos["estado"]].'%3E %3Cb%3E'.$rs->campos["descripcion"].' %3C/b%3E'; |
|---|
| 573 | $AuxcadenaXML.=' (%3Cb%3E'.$TbMsg[15].":%3C/b%3E".$anno_c.')"'; |
|---|
| 574 | |
|---|
| 575 | $AuxcadenaXML.=' nodoid=reserva-'.$rs->campos["idreserva"]; |
|---|
| 576 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 577 | $AuxcadenaXML.=' fondonodo='."#EEEECC;"; |
|---|
| 578 | $AuxcadenaXML.='>'; |
|---|
| 579 | |
|---|
| 580 | $AuxcadenaXML.='<OCUPACION '; |
|---|
| 581 | // Atributos |
|---|
| 582 | $AuxcadenaXML.=' imagenodo="../images/iconos/nada.gif"'; |
|---|
| 583 | //___________________________________________________________________________ |
|---|
| 584 | $HTMLannos="<TABLE><TR>"; |
|---|
| 585 | for ($i=$mes_desde;$i<=$mes_hasta;$i++){ |
|---|
| 586 | if($i%7==0) $HTMLannos.="</TR><TR>"; |
|---|
| 587 | $HTMLannos.='<TD style="BACKGROUND-COLOR:#FFFFFF" valign=top>'; |
|---|
| 588 | $HTMLannos.=$calendario->JMesAnno($i,$anno_c,$JDif,$TBfechas,$wsumahoras); |
|---|
| 589 | $HTMLannos.='</TD>'; |
|---|
| 590 | } |
|---|
| 591 | $HTMLannos.="</TR></TABLE>"; |
|---|
| 592 | //___________________________________________________________________________ |
|---|
| 593 | $AuxcadenaXML.=' infonodo='.urlencode($HTMLannos); |
|---|
| 594 | $AuxcadenaXML.=' nodoid=opcupacion'; |
|---|
| 595 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 596 | $AuxcadenaXML.=' fondonodo='."#FFFFFF;"; |
|---|
| 597 | $AuxcadenaXML.='>'; |
|---|
| 598 | $AuxcadenaXML.='</OCUPACION>'; |
|---|
| 599 | |
|---|
| 600 | /* |
|---|
| 601 | $AuxcadenaXML.='<RESERVA '; |
|---|
| 602 | // Atributos |
|---|
| 603 | $AuxcadenaXML.=' imagenodo="../images/iconos/carpeta.gif"'; |
|---|
| 604 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[30].':%3C/b%3E "'; |
|---|
| 605 | $AuxcadenaXML.=' nodoid=reserva'; |
|---|
| 606 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 607 | $AuxcadenaXML.='>'; |
|---|
| 608 | */ |
|---|
| 609 | |
|---|
| 610 | // Cuestion Ocupación |
|---|
| 611 | $hexhoradesde=$rs->campos["horasini"]; |
|---|
| 612 | $minutosdesde=$rs->campos["minutosini"]; |
|---|
| 613 | if($minutosdesde==0) $minutosdesde="00"; |
|---|
| 614 | $minutosdesde.=" ".$tbampm[$rs->campos["ampmini"]]; |
|---|
| 615 | $hexhorahasta=$rs->campos["horasfin"]; |
|---|
| 616 | $minutoshasta=$rs->campos["minutosfin"]; |
|---|
| 617 | if($minutoshasta==0) $minutoshasta="00"; |
|---|
| 618 | $minutoshasta.=" ".$tbampm[$rs->campos["ampmfin"]]; |
|---|
| 619 | $cont=0; |
|---|
| 620 | while($hexhoradesde>0){ |
|---|
| 621 | $cont++; |
|---|
| 622 | $hexhoradesde=$hexhoradesde>>1; |
|---|
| 623 | } |
|---|
| 624 | $horadesde=$cont-1; |
|---|
| 625 | $cont=0; |
|---|
| 626 | while($hexhorahasta>0){ |
|---|
| 627 | $cont++; |
|---|
| 628 | $hexhorahasta=$hexhorahasta>>1; |
|---|
| 629 | } |
|---|
| 630 | $horahasta=$cont-1; |
|---|
| 631 | |
|---|
| 632 | $mulmin=floor($minutosdesde/15); |
|---|
| 633 | $currentminutos=$mulmin*15; |
|---|
| 634 | $CntDia[(int)$rs->campos["ampmini"]][(int)$horadesde][(int)$currentminutos]=1; |
|---|
| 635 | $mulmin=floor($minutoshasta/15); |
|---|
| 636 | $currentminutos=$mulmin*15; |
|---|
| 637 | $CntDia[(int)$rs->campos["ampmfin"]][(int)$horahasta][(int)$currentminutos]=0; |
|---|
| 638 | |
|---|
| 639 | $AuxcadenaXML.='<OCUPACION '; |
|---|
| 640 | // Atributos |
|---|
| 641 | $AuxcadenaXML.=' imagenodo="../images/iconos/reloj.gif"'; |
|---|
| 642 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[19].':%3C/b%3E '.$horadesde.":".$minutosdesde." - ".$horahasta.":".$minutoshasta.'"'; |
|---|
| 643 | $AuxcadenaXML.=' nodoid=opcupacion-'.$horadesde.":".$minutosdesde." - ".$horahasta.":".$minutoshasta; |
|---|
| 644 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 645 | $AuxcadenaXML.=' fondonodo='."#FBECFA;"; |
|---|
| 646 | $AuxcadenaXML.='>'; |
|---|
| 647 | $AuxcadenaXML.='</OCUPACION>'; |
|---|
| 648 | |
|---|
| 649 | $idaula=$rs->campos["idaula"]; |
|---|
| 650 | $nombreaula=$rs->campos["nombreaula"]; |
|---|
| 651 | $AuxcadenaXML.='<AULA '; |
|---|
| 652 | // Atributos |
|---|
| 653 | $AuxcadenaXML.=' imagenodo="../images/iconos/aula.gif"'; |
|---|
| 654 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[24].':%3C/b%3E '.$nombreaula.'"';; |
|---|
| 655 | $AuxcadenaXML.=' nodoid=aula-'.$rs->campos["idaula"]; |
|---|
| 656 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 657 | $AuxcadenaXML.=' fondonodo='."#FBECFA;"; |
|---|
| 658 | $AuxcadenaXML.='>'; |
|---|
| 659 | $AuxcadenaXML.='</AULA>'; |
|---|
| 660 | |
|---|
| 661 | $nombreimagen=$rs->campos["nombreimagen"]; |
|---|
| 662 | if(empty($nombreimagen) ) $nombreimagen=$TbMsg[23]; |
|---|
| 663 | // Descripción de la imagen a restaurar |
|---|
| 664 | $AuxcadenaXML.='<IMAGEN '; |
|---|
| 665 | // Atributos |
|---|
| 666 | $AuxcadenaXML.=' imagenodo="../images/iconos/imagenes.gif"'; |
|---|
| 667 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[20].': %3C/b%3E'.$nombreimagen.'"'; |
|---|
| 668 | $AuxcadenaXML.=' nodoid=imagen-'.$rs->campos["idimagen"]; |
|---|
| 669 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 670 | $AuxcadenaXML.=' fondonodo='."#FBECFA;"; |
|---|
| 671 | $AuxcadenaXML.='>'; |
|---|
| 672 | $AuxcadenaXML.='</IMAGEN>'; |
|---|
| 673 | |
|---|
| 674 | $nombretarea=$rs->campos["nombretarea"]; |
|---|
| 675 | if(!empty($nombretarea) ){ |
|---|
| 676 | // Descripción de la tarea a restaurar |
|---|
| 677 | $AuxcadenaXML.='<TAREA '; |
|---|
| 678 | // Atributos |
|---|
| 679 | $AuxcadenaXML.=' imagenodo="../images/iconos/tareas.gif"'; |
|---|
| 680 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[28].': %3C/b%3E'.$nombretarea.'"'; |
|---|
| 681 | $AuxcadenaXML.=' nodoid=tarea-'.$rs->campos["idtarea"]; |
|---|
| 682 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 683 | $AuxcadenaXML.=' fondonodo='."#FBECFA;"; |
|---|
| 684 | $AuxcadenaXML.='>'; |
|---|
| 685 | $AuxcadenaXML.='</TAREA>'; |
|---|
| 686 | } |
|---|
| 687 | $nombretrabajo=$rs->campos["nombretrabajo"]; |
|---|
| 688 | if(!empty($nombretrabajo) ){ |
|---|
| 689 | // Descripción del trabajo a restaurar |
|---|
| 690 | $AuxcadenaXML.='<TRABAJO '; |
|---|
| 691 | // Atributos |
|---|
| 692 | $AuxcadenaXML.=' imagenodo="../images/iconos/trabajos.gif"'; |
|---|
| 693 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[29].': %3C/b%3E'.$nombretrabajo.'"'; |
|---|
| 694 | $AuxcadenaXML.=' nodoid=trabajo-'.$rs->campos["idtrabajo"]; |
|---|
| 695 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 696 | $AuxcadenaXML.=' fondonodo='."#FBECFA;"; |
|---|
| 697 | $AuxcadenaXML.='>'; |
|---|
| 698 | $AuxcadenaXML.='</TRABAJO>'; |
|---|
| 699 | } |
|---|
| 700 | $AuxcadenaXML.='<EMAIL '; |
|---|
| 701 | // Atributos |
|---|
| 702 | $AuxcadenaXML.=' imagenodo="../images/iconos/email.gif"'; |
|---|
| 703 | $AuxcadenaXML.=' infonodo="%3Cb%3E'.$TbMsg[25].':%3C/b%3E '.$rs->campos["solicitante"].' (%3CA href=mailto:'.$rs->campos["email"].'%3E'.$rs->campos["email"].'%3C/A%3E)"'; |
|---|
| 704 | $AuxcadenaXML.=' nodoid=email-'.$idaula; |
|---|
| 705 | $AuxcadenaXML.=' colornodo='."#000000"; |
|---|
| 706 | $AuxcadenaXML.=' fondonodo='."#FBECFA;"; |
|---|
| 707 | $AuxcadenaXML.='>'; |
|---|
| 708 | $AuxcadenaXML.='</EMAIL>'; |
|---|
| 709 | |
|---|
| 710 | |
|---|
| 711 | //$AuxcadenaXML.='</RESERVA> '; |
|---|
| 712 | $AuxcadenaXML.='</RESERVAS>'; |
|---|
| 713 | return($AuxcadenaXML); |
|---|
| 714 | } |
|---|
| 715 | //________________________________________________________________________________________________________ |
|---|
| 716 | function CalculaMinutos($rs){ |
|---|
| 717 | $hexhoradesde=$rs->campos["horasini"]; |
|---|
| 718 | $hexhorahasta=$rs->campos["horasfin"]; |
|---|
| 719 | $cont=0; |
|---|
| 720 | while($hexhoradesde>0){ |
|---|
| 721 | $cont++; |
|---|
| 722 | $hexhoradesde=$hexhoradesde>>1; |
|---|
| 723 | } |
|---|
| 724 | $shorasini=$cont-1; |
|---|
| 725 | $cont=0; |
|---|
| 726 | while($hexhorahasta>0){ |
|---|
| 727 | $cont++; |
|---|
| 728 | $hexhorahasta=$hexhorahasta>>1; |
|---|
| 729 | } |
|---|
| 730 | $shorasfin=$cont-1; |
|---|
| 731 | $sminutosini=$rs->campos["minutosini"]; |
|---|
| 732 | $sminutosfin=$rs->campos["minutosfin"]; |
|---|
| 733 | if($rs->campos["ampmini"]==1) $shorasini+=12; |
|---|
| 734 | if($rs->campos["ampmfin"]==1) $shorasfin+=12; |
|---|
| 735 | $socupacion=($shorasfin-$shorasini)*60+($sminutosfin-$sminutosini); |
|---|
| 736 | return($socupacion); |
|---|
| 737 | } |
|---|
| 738 | /*________________________________________________________________________________________________________ |
|---|
| 739 | Recorrea los distintos ámbitos |
|---|
| 740 | ________________________________________________________________________________________________________*/ |
|---|
| 741 | function RecorreCentro($cmd){ |
|---|
| 742 | global $AMBITO_CENTROS; |
|---|
| 743 | global $LITAMBITO_CENTROS; |
|---|
| 744 | global $AMBITO_GRUPOSAULAS; |
|---|
| 745 | global $idambito,$nombreambito; |
|---|
| 746 | |
|---|
| 747 | $rs=new Recordset; |
|---|
| 748 | $rs->Comando=&$cmd; |
|---|
| 749 | if (!$rs->Abrir()) return; // Error al abrir recordset |
|---|
| 750 | $rs->Primero(); |
|---|
| 751 | if(!$rs->EOF){ |
|---|
| 752 | $idcentro=$rs->campos["idcentro"]; |
|---|
| 753 | $cmd->texto="SELECT idgrupo FROM grupos WHERE idcentro=".$idcentro." AND grupoid=0 AND tipo=".$AMBITO_GRUPOSAULAS; |
|---|
| 754 | RecorreGruposAulas($cmd); |
|---|
| 755 | $cmd->texto="SELECT idaula FROM aulas WHERE idcentro=".$idcentro." AND grupoid=0"; |
|---|
| 756 | RecorreAulas($cmd); |
|---|
| 757 | } |
|---|
| 758 | $rs->Cerrar(); |
|---|
| 759 | } |
|---|
| 760 | //________________________________________________________________________________________________________ |
|---|
| 761 | function RecorreGruposAulas($cmd){ |
|---|
| 762 | global $AMBITO_GRUPOSAULAS; |
|---|
| 763 | global $LITAMBITO_GRUPOSAULAS; |
|---|
| 764 | |
|---|
| 765 | $rs=new Recordset; |
|---|
| 766 | $cmd->texto.="ORDER by nombregrupo"; |
|---|
| 767 | $rs->Comando=&$cmd; |
|---|
| 768 | if (!$rs->Abrir()) return; // Error al abrir recordset |
|---|
| 769 | $rs->Primero(); |
|---|
| 770 | while (!$rs->EOF){ |
|---|
| 771 | $idgrupo=$rs->campos["idgrupo"]; |
|---|
| 772 | $cmd->texto="SELECT idgrupo FROM grupos WHERE grupoid=".$idgrupo ." AND tipo=".$AMBITO_GRUPOSAULAS; |
|---|
| 773 | RecorreGruposAulas($cmd); |
|---|
| 774 | $cmd->texto="SELECT idaula FROM aulas WHERE grupoid=".$idgrupo; |
|---|
| 775 | RecorreAulas($cmd); |
|---|
| 776 | $rs->Siguiente(); |
|---|
| 777 | } |
|---|
| 778 | $rs->Cerrar(); |
|---|
| 779 | } |
|---|
| 780 | //________________________________________________________________________________________________________ |
|---|
| 781 | function RecorreAulas($cmd){ |
|---|
| 782 | global $AMBITO_AULAS; |
|---|
| 783 | global $LITAMBITO_AULAS; |
|---|
| 784 | global $cadenaaulas; |
|---|
| 785 | |
|---|
| 786 | $rs=new Recordset; |
|---|
| 787 | $cmd->texto.="ORDER by nombreaula"; |
|---|
| 788 | $rs->Comando=&$cmd; |
|---|
| 789 | if (!$rs->Abrir()) return; // Error al abrir recordset |
|---|
| 790 | $rs->Primero(); |
|---|
| 791 | while (!$rs->EOF){ |
|---|
| 792 | $idaula=$rs->campos["idaula"]; |
|---|
| 793 | $cadenaaulas.=$idaula.","; |
|---|
| 794 | $rs->Siguiente(); |
|---|
| 795 | } |
|---|
| 796 | $rs->Cerrar(); |
|---|
| 797 | } |
|---|
| 798 | //________________________________________________________________________________________________________ |
|---|
| 799 | function RecorreGruposReservas($cmd){ |
|---|
| 800 | global $AMBITO_GRUPOSRESERVAS; |
|---|
| 801 | global $LITAMBITO_GRUPOSRESERVAS; |
|---|
| 802 | |
|---|
| 803 | $rs=new Recordset; |
|---|
| 804 | $rs->Comando=&$cmd; |
|---|
| 805 | if (!$rs->Abrir()) return; // Error al abrir recordset |
|---|
| 806 | $rs->Primero(); |
|---|
| 807 | while (!$rs->EOF){ |
|---|
| 808 | $idgrupo=$rs->campos["idgrupo"]; |
|---|
| 809 | $cmd->texto="SELECT idgrupo FROM grupos WHERE grupoid=".$idgrupo ." AND tipo=".$AMBITO_GRUPOSRESERVAS; |
|---|
| 810 | RecorreGruposReservas($cmd); |
|---|
| 811 | $cmd->texto="SELECT idreserva FROM reservas WHERE grupoid=".$idgrupo; |
|---|
| 812 | RecorreReservas($cmd); |
|---|
| 813 | $rs->Siguiente(); |
|---|
| 814 | } |
|---|
| 815 | $rs->Cerrar(); |
|---|
| 816 | } |
|---|
| 817 | //________________________________________________________________________________________________________ |
|---|
| 818 | function RecorreReservas($cmd){ |
|---|
| 819 | global $AMBITO_RESERVAS; |
|---|
| 820 | global $LITAMBITO_RESERVAS; |
|---|
| 821 | global $cadenareservas; |
|---|
| 822 | |
|---|
| 823 | $rs=new Recordset; |
|---|
| 824 | $rs->Comando=&$cmd; |
|---|
| 825 | if (!$rs->Abrir()) return; // Error al abrir recordset |
|---|
| 826 | $rs->Primero(); |
|---|
| 827 | while (!$rs->EOF){ |
|---|
| 828 | $idreserva=$rs->campos["idreserva"]; |
|---|
| 829 | $cadenareservas.=$idreserva.","; |
|---|
| 830 | $rs->Siguiente(); |
|---|
| 831 | } |
|---|
| 832 | $rs->Cerrar(); |
|---|
| 833 | } |
|---|
| 834 | ?> |
|---|