Ver Mensaje Individual
  #1 (permalink)  
Antiguo 06/09/2007, 19:30
RbR
 
Fecha de Ingreso: febrero-2006
Mensajes: 11
Antigüedad: 18 años, 2 meses
Puntos: 0
Seleccionar intervalo de fechas en un calendario

Hola estoy intentando hacer un calendario para una casa rural y necesito que me seleccione los dias que esta en reserva. Para ello meto los datos de fecha de entrada y fecha de salida en la bd por un formulario (ej. 1/6/2007).

Hasta ahi bien pero cuando quiero que me seleccione el intervalo no soy capaz a que me funcione.
Lo he intentado haciendo una consulta que mire si el dia que esta imprimiendo esta dentro del intervalo de inicio y fin, y me he quedado ahi.. estoy atascado.

Lo he intentando con un between que consulte que si el dia que esta imprimiendo este entre los valores de inicio y fin ty tambien con una consulta que mire si el dia que imprime es mayor o menor a la fecha de inicio y que tambien sea menor a la fecha final, pero tambien sin ningun exito :(

Haber si alguien puede hecharme una mano que estoy desesperado yaaaaaaa !!!!!!!!!!!!!!!!!!!!!

La funcion que imprime los dias del calendario:

Código PHP

function mostrar_calendario($mes,$ano){
global $parametros_formulario;
//tomo el nombre del mes que hay que imprimir
$nombre_mes = dame_nombre_mes($mes);

//construyo la cabecera de la tabla
echo "<table width=200% cellspacing=3 cellpadding=2 border=1><tr><td colspan=7 align=center class=tit>";
echo "<table width=100% cellspacing=2 cellpadding=2 border=0><tr><td style=font-size:10pt;font-weight:bold;color:white>";
//calculo el mes y ano del mes anterior
$mes_anterior = $mes - 1;
$ano_anterior = $ano;
if ($mes_anterior==0){
$ano_anterior--;
$mes_anterior=12;
}
echo "<a style=color:white;text-decoration:none href=index.php?$parametros_formulario&nuevo_mes=$m es_anterior&nuevo_ano=$ano_anterior>&lt;&lt;</a></td>";
echo "<td align=center class=tit>$nombre_mes $ano</td>";
echo "<td align=right style=font-size:10pt;font-weight:bold;color:white>";
//calculo el mes y ano del mes siguiente
$mes_siguiente = $mes + 1;
$ano_siguiente = $ano;
if ($mes_siguiente==13){
$ano_siguiente++;
$mes_siguiente=1;
}
echo "<a style=color:white;text-decoration:none href=index.php?$parametros_formulario&nuevo_mes=$m es_siguiente&nuevo_ano=$ano_siguiente>&gt;&gt;</a></td></tr></table></td></tr>";
echo ' <tr>
<td width=14% align=center class=altn>L</td>
<td width=14% align=center class=altn>M</td>
<td width=14% align=center class=altn>X</td>
<td width=14% align=center class=altn>J</td>
<td width=14% align=center class=altn>V</td>
<td width=14% align=center class=altn>S</td>
<td width=14% align=center class=altn>D</td>
</tr>';

//Variable para llevar la cuenta del dia actual
$dia_actual = 1;

//calculo el numero del dia de la semana del primer dia
$numero_dia = calcula_numero_dia_semana(1,$mes,$ano);
//echo "Numero del dia de demana del primer: $numero_dia <br>";

//calculo el último dia del mes
$ultimo_dia = ultimoDia($mes,$ano);

//escribo la primera fila de la semana
echo "<tr>";
for ($i=0;$i<7;$i++){
if ($i < $numero_dia){
//si el dia de la semana i es menor que el numero del primer dia de la semana no pongo nada en la celda
echo "<td></td>";
} else {
echo "<td align=center><a href='javascript:devuelveFecha($dia_actual,$mes,$a no)'". dame_estilo($dia_actual) .">$dia_actual</a></td>";
$dia_actual++;
}
}
echo "</tr>";

//recorro todos los demás días hasta el final del mes

$numero_dia = 0;

while ($dia_actual <= $ultimo_dia){
//AQUI COMIENZA EL LIO NO SE COMO HACER LA CONSULTA
$fecha_del_dia = $dia_actual.-$mes.-$ano;
$fecha_del_fin = $ultimo_dia.-$mes.-$ano;
$result_mirar = "SELECT * FROM eventos WHERE fecha_inicio BETWEEN '$fecha_del_dia' AND '$fecha_del_fin'";

$marca_dias = mysql_query($result_mirar,$link);
//si estamos a principio de la semana escribo el <TR>
if ($numero_dia == 0)
echo "<tr>";
if ( mysql_fetch_row ($marca_dias))
echo '<td bgcolor=FF0000 align=center>',$dia_actual,'</td>';
else
echo '<td align=center>',$dia_actual,'</td>';
//echo "<td align=center><a href='javascript:devuelveFecha($dia_actual,$mes,$a no)'". dame_estilo($dia_actual) .">$dia_actual</a></td>";
$dia_actual++;
$numero_dia++;
//si es el uñtimo de la semana, me pongo al principio de la semana y escribo el </tr>
if ($numero_dia == 7){
$numero_dia = 0;
echo "</tr>";
}
}

//compruebo que celdas me faltan por escribir vacias de la última semana del mes
for ($i=$numero_dia;$i<7;$i++){
echo "<td></td>";
}

echo "</tr>";
echo "</table>";
}

Última edición por RbR; 10/09/2007 a las 22:09