Foros del Web » Programando para Internet » PHP »

Seleccionar intervalo de fechas en un calendario

Estas en el tema de Seleccionar intervalo de fechas en un calendario en el foro de PHP en Foros del Web. 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 ...
  #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
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 05:55.