Foros del Web » Programando para Internet » PHP »

Calendario Para Reservas.

Estas en el tema de Calendario Para Reservas. en el foro de PHP en Foros del Web. Hola Foreros. Hoy vengo con una problema que me resulta bastante complicado, mas de lo que pensaba. Me gustaría añadir en una parte de mi ...
  #1 (permalink)  
Antiguo 05/12/2014, 08:07
Avatar de HackID1  
Fecha de Ingreso: febrero-2013
Ubicación: En Update
Mensajes: 492
Antigüedad: 11 años, 2 meses
Puntos: 17
Pregunta Calendario Para Reservas.

Hola Foreros. Hoy vengo con una problema que me resulta bastante complicado, mas de lo que pensaba.

Me gustaría añadir en una parte de mi web un calendario el cual se pueda navegar por el y elegir el día en el que se quiera hacer la reserva.

He visto este post anterior pero en sí no veo respuesta para poder solucionar este problema.
llamando_consulta_sql_desde_calendario_eventos

He visto este CALENDARIO y es justo lo que me haría falta, solo le faltaría la reseña cuando te posicionas encima con el ratón por JScript.
Calendario_perfecto

El calendario se mostraría en la web y debe permitir que elijas un día y situando el ratón encima ver que es lo que se ha reservado ese día.

Si el día que escoges no tiene nada reservado que te lleve a un formulario, aquí rellenas los datos de reserva, y aceptas con lo que ya se reserva ese día y hora para ti.

Si vuelves al calendario debe aparecer ese día reservado!!!. Y situandose encima con el ratón (supongo que es JScript) mostrar una pequeña ficha de lo que se ha reservado.

Esto debe controlarse con JScript, PHP y BD (para tener control de las reservas y quien la ha reservado).

Estuve mirando varios calendarios y encontré este pero veo montón de información que para el poco tiempo que dispongo no me daría tiempo a conocer como implementar en JQuery este calendario.

Calendario:
http://fullcalendar.io/

Algunas formas de uso:
http://fullcalendar.io/docs/usage/

Es bastante amplia la info, podrían darme una idea.

Simplemente quisiera mostrar un calendario, permitir elegir un día y este lleve al formulario, rellenar los datos y hacer la reserva. Posteriormente volver al calendario y si hay días ocupados que se vean en NEGRO y posiciones encima el ratón y te muestre una pequeña reseña. (titulo, descrip corta y foto por ejemplo).

Saludos y muchas gracias si alguien puede guiarme para realizar este calendario.
__________________
Puntuar +1 es buena forma de dar las gracias. :P
Your Time is limited, so don't waste it living someone else´s life.
Por: HackID1

Última edición por HackID1; 05/12/2014 a las 08:21
  #2 (permalink)  
Antiguo 05/12/2014, 12:09
Avatar de NSD
NSD
Colaborador
 
Fecha de Ingreso: mayo-2012
Ubicación: Somewhere
Mensajes: 1.332
Antigüedad: 11 años, 11 meses
Puntos: 320
Respuesta: Calendario Para Reservas.

Podrias hacer algo desde 0, vamos que tampoco es tan dificil.

Por ejemplo:

calendario.js
Código Javascript:
Ver original
  1. var eventos = document.getElementsByClassName("evento");
  2. for(var evt = 0; evt<eventos.length; evt++)
  3. {
  4.     eventos[evt].addEventListener("click", function(){
  5.         var lista = document.getElementsByTagName("li");
  6.         for(var li = 0; li<lista.length; li++)
  7.             lista[li].classList.remove("active");
  8.         document.getElementById("evnt_"+this.dataset.fecha).classList.add("active");
  9.     }, false);
  10. }

calendario.css
Código CSS:
Ver original
  1. table
  2. {  
  3.     width: 400px;
  4.     float: left;
  5. }
  6. td
  7. {
  8.     padding: 10px;
  9.     border: 1px solid #eee;
  10.     text-align: center;
  11. }
  12. td.evento
  13. {
  14.     background: #eee;
  15. }
  16. td.evento.reserva
  17. {
  18.     border-color: red;
  19. }
  20. ul
  21. {
  22.     width: 400px;
  23.     float: left;
  24. }
  25. ul > li
  26. {
  27.     display: none;
  28. }
  29. ul > li.active
  30. {
  31.     display: block !important;
  32. }
  33. ul > li > img
  34. {
  35.     float: left;
  36.     width: 200px;
  37. }

calendario.php
Código PHP:
Ver original
  1. <?php
  2.     $mes_a_mostrar = "2014-12";
  3.  
  4.     // Esto lo obtines de una bd.
  5.     $eventos_mes = [
  6.         "2014-12-05" => [
  7.             "titulo" => "Responder un tema",
  8.             "lugar"  => "Foros del web",
  9.             "imagen" => "http://www.maestrosdelweb.com/images/2008/11/isotipofdw_hr.png",
  10.             "descripcion" => "Ejemplo de datos de calendario."
  11.         ],
  12.         "2014-12-15" => [
  13.             "titulo" => "Responder otro tema",
  14.             "lugar"  => "Foros del web",
  15.             "imagen" => "http://www.maestrosdelweb.com/images/2008/11/isotipofdw_hr.png",
  16.             "descripcion" => "Ejemplo de datos de otro calendario."
  17.         ]
  18.     ];
  19.  
  20.     $reservas_mes = [
  21.         "2014-12-15" => [
  22.             [
  23.                 "nombre" => "Persona 1",
  24.                 "butaca"  => 1
  25.             ],
  26.             [
  27.                 "nombre" => "Persona 2",
  28.                 "butaca"  => 2
  29.             ]
  30.         ]
  31.     ];
  32. ?>
  33. <html>
  34.     <head>
  35.         <title>Calendario</title>
  36.        <link rel="stylesheet" type="text/css" href="calendario.css">
  37.     </head>
  38.     <body>
  39.         <table>
  40.             <tr>
  41.                 <th colspan="7"><?=$mes_a_mostrar;?></th>
  42.             </tr>
  43.             <tr>
  44.                 <th>Domingo</th>
  45.                 <th>Lunes</th>
  46.                 <th>Martes</th>
  47.                 <th>Miercoles</th>
  48.                 <th>Jueves</th>
  49.                 <th>Viernes</th>
  50.                 <th>Sabado</th>
  51.             </tr>
  52.             <tr>
  53.             <?php
  54.                 $inicio = date('w', strtotime($mes_a_mostrar."-01"));
  55.                 $dias = cal_days_in_month(CAL_GREGORIAN, 12, 2014);
  56.                 echo str_repeat("<td></td>", $inicio);
  57.                 for($dia = $inicio; $dia<$dias; $dia++)
  58.                 {
  59.                     if(!(($dia)%7))
  60.                         echo("</tr><tr>");
  61.                     $dia = ($dia < 10 ? "0$dia" : $dia);
  62.                     $class = (isset($eventos_mes["$mes_a_mostrar-$dia"]) ? "evento" : "");
  63.                     $class .= (isset($reservas_mes["$mes_a_mostrar-$dia"]) ? " reserva" : "");
  64.  
  65.                     echo("<td class=\"$class\" data-fecha=\"$mes_a_mostrar-$dia\">".($dia*1)."</td>");
  66.                 }
  67.             ?>
  68.             </tr>
  69.         </table>
  70.         <ul>
  71.             <?php
  72.                 foreach($eventos_mes as $fecha => $evento)
  73.                 {
  74.             ?>
  75.             <li id="evnt_<?=$fecha;?>">
  76.                 <img src="<?=$evento["imagen"];?>">
  77.                 <strong><?=$fecha;?></strong>
  78.                 <h3><?=$evento["titulo"];?></h3>
  79.                 <h5><?=$evento["lugar"];?></h5>
  80.                 <p><?=$evento["descripcion"];?></p>
  81.                 <?php
  82.                     if(isset($reservas_mes[$fecha]))
  83.                     {
  84.                 ?>
  85.                     <table>
  86.                         <tr>
  87.                             <th>Persona</th>
  88.                             <th>Butaca</th>
  89.                         </tr>
  90.                     <?php
  91.                         foreach($reservas_mes[$fecha] as $reserva)
  92.                         {
  93.                     ?>
  94.                         <tr>
  95.                             <td><?=$reserva["nombre"];?></td>
  96.                             <td><?=$reserva["butaca"];?></td>
  97.                         </tr>
  98.                     <?php
  99.                         }
  100.                     ?>
  101.                     </table>
  102.                 <?php
  103.                     }
  104.                 ?>
  105.             </li>
  106.             <?php
  107.                 }
  108.             ?>
  109.         </ul>
  110.         <script src="calendario.js"></script>
  111.     </body>
  112. </html>

Solo te queda agregar el formulario y hacerlo funcionar.
__________________
Maratón de desafíos PHP Junio - Agosto 2015 en FDW | Reglamento - Desafios

Última edición por NSD; 06/12/2014 a las 11:53
  #3 (permalink)  
Antiguo 06/12/2014, 08:21
Avatar de HackID1  
Fecha de Ingreso: febrero-2013
Ubicación: En Update
Mensajes: 492
Antigüedad: 11 años, 2 meses
Puntos: 17
Respuesta: Calendario Para Reservas.

Y cómo podría hacer para en ese mismo calendario mostrar unas flechas de navegación para tener todos los meses, es decir un calendario completo meses y años.

Gracias por la ayuda!!!. estoy ahora probando cosas, pero si me haría mucha falta tener todos los meses, podría ser en un array o algo.
__________________
Puntuar +1 es buena forma de dar las gracias. :P
Your Time is limited, so don't waste it living someone else´s life.
Por: HackID1
  #4 (permalink)  
Antiguo 06/12/2014, 11:55
Avatar de NSD
NSD
Colaborador
 
Fecha de Ingreso: mayo-2012
Ubicación: Somewhere
Mensajes: 1.332
Antigüedad: 11 años, 11 meses
Puntos: 320
Respuesta: Calendario Para Reservas.

Cita:
podría ser en un array o algo.
Podrían ser muchas cosas. Ya te di una idea, solo tienes que adaptarla a tus necesidades.
__________________
Maratón de desafíos PHP Junio - Agosto 2015 en FDW | Reglamento - Desafios
  #5 (permalink)  
Antiguo 12/12/2014, 16:44
Avatar de HackID1  
Fecha de Ingreso: febrero-2013
Ubicación: En Update
Mensajes: 492
Antigüedad: 11 años, 2 meses
Puntos: 17
Respuesta: Calendario Para Reservas.

Muchas gracias por las respuestas, actualmente estoy realizando todo usando un calendario creando este por medio de Ajax y PHP. Por ahora todo funcionando, sólo me queda permitir registrar el mismo evento en un rango de días.

Ejm: En el calendario selecciono el día 2, creo el evento y elijo la opción para ampliar ese evento desde el día 2 hasta el 4.

Por tanto el evento saldrá en los días 2, 3 y 4 .

Alguna idea de como realizar esta opción así por encima?
Saludos y muchas gracias a este foro siempre me es de muchísima ayuda y intento devolver estos grandes favores lo mejor que puedo. ;)
__________________
Puntuar +1 es buena forma de dar las gracias. :P
Your Time is limited, so don't waste it living someone else´s life.
Por: HackID1

Etiquetas: calendario, formulario
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 23:15.