+ Rispondi alla Discussione
Risultati da 1 a 28 di 28

[Script] Calendario prenotazioni

Ultimo Messaggio di maramau79 il:
  1. #1
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin

    [Script] Calendario prenotazioni

    Ciao bella gente.

    Siccome è un po' che mi sbatto per creare una web-application che mi permetta di gestire le prenotazioni di una struttura alberghiera, ho pensato di pubblicare il calendario prenotazioni.

    I requisiti sono:
    - Modulo PHP 5 >
    - Un database MySQL
    - Conoscenza di PHP

    Ovviamente con il solo script c'è da farci poco davvero, bisognerà costruirgli attorno tutta una struttura di file e tabelle del Db per ottenere ciò che serve.

    Ma partiamo dall'idea...
    il mio punto di partenza è stato questo script di PaTer, che poi ho modificato per le mie esigenze, ma ha di certo rappresentato la scintilla per partire con il progetto che sto portando avanti.
    Volendo ottenere un planner mensile di tutte le stanze, e che in questo planner mi si visualizzino, in maniera ben evidente, le date in cui le stanze son occupate, quali sono i giorni in cui ho una partenza la mattina ed un arrivo il pomeriggio, magari per la stessa stanza, cosa molto importante è anche riconoscere a vista se le prenotazione inserita è già stata confermata o per il momento è solo una richiesta disponibilità a cui non è stato dato un seguito, quindi una stanza potenzialmente ancora libera per quel periodo, di lavoro da fare ce n'è molto e per prima cosa il calendario va sicuramente sviluppato in orizzontale, una riga per stanza.

    Siccome non mi basta... () ...voglio pure che quando mi posiziono su un periodo prenotato mi si visualizzino almeno i dati salienti della prenotazione, chi è il cliente e quali sono le date di check-in e check-out, cliccando invece sulla prenotazione come minimo devo vedere tutti i dettagli della stessa.

    Di soluzioni per ottenere tutto questo ce ne saranno a bizzeffe ma mi sono posto il problema di appesantire il meno possibile il server...perché un planner che per caricare ci sta 10 secondi... non si può vedere...

    La soluzione che ho trovato è quella di, ovviamente, ridurre al minimo le query e limitare al massimo l'uso delle funzioni. Per fare tutto questo devo quindi incamerare i dati raccolti in maniera che poi li possa riutilizzare in maniera semplice e senza ricorrere ad ulteriori query o funzioni. E cosa meglio degli array?


    Con i giusti cicli e controlli sembrerebbe che la soluzione trovata funzioni.
    Query:
    Un primo ciclo serve a creare le righe, quindi le stanze, per ogni stanza poi recupero le prenotazioni che incidono nel mese visualizzato e per ogni prenotazione mi recupero l'anagrafica del cliente. Non ho bisogno di altri dati, questi già mi avanzano.

    Array:
    Per gli array, anche per un ulteriore utilizzo futuro, ho pensato di dare un indice numerico che sia uguale al timestamp del giorno, così da essere certamente univoco e utilizzabile per qualsivoglia altro sviluppo, la progressione degli indici quindi viene data dall'incremento in secondi di 1 giorno, ovvero 86400. Unico problema sorge nei mesi con il cambio ora legale/ora solare, problema che comunque si risolve con la giusta verifica sommando o sottraendo 3600 secondi (1 ora) dalla data recuperata dal Db, in quanto quella sarà già adeguata al cambio orario una volta inserita, mentre incrementando i valori indice di 86400 secondi per ogni giorno ovviamente ci si troverebbe ad avere degli indici sfalsati di 3600 secondi raggiunta la data del cambio orario.

    Il risultato di tutto questo sarà un planner mensile, che mi permette di muovermi tra i vari mesi, dove in verde ci saranno i giorni liberi, la distinzione tra stato "prenotato" e "confermato" che è data nel primo dal colore giallo ed il secondo dal colore rosso, e, cosa molto importante, le date di inizio e fine soggiorno saranno di un sfumatura più chiara per evidenziare l'inizio e fine dello stesso. Qualora in pari giornata si avesse un check-out ed un check-in questi giorni saranno marcati da un colore più forte (viola per i confermati e arancione per i prenotati). Posizionandosi sui periodi prenotati mi visualizzerà come title del link "Prenotazione Mario Rossi dal 01/01/2010 al 06/01/2010" e cliccando si accederà alla pagina prenotazione dove recuperato l'id della prenotazione si può ovviamente sviluppare un po' di tutto e di tutto un po'.

    Ma buttiamo giù un po' di codice, già parzialmente commentato:
    Codice PHP:
    <?php
    //inseriamo i parametri di connessione al Database
    $db_host "indirizzoservermysql";
    $db_user "nomeutentemysql";
    $db_pass "passwordmysql";
    $db_name "nomedatabase";

    $connection = @mysql_connect($db_host,$db_user,$db_pass)
        or die (
    "Connessione al server non stabilita");
    $db = @mysql_select_db($db_name,$connection)
        or die (
    "Connessione al Db non stabilita");

    //Se cambio mese procedo al recupero dei dati postati.
    $mese="";
    $anno="";
    $mese=$_POST['mese'];
    $anno=$_POST['anno'];
    if (
    $mese==""//se il mese non è stato valorizzato
    {
        
    $time=time(); //il parametro time sarà uguale al timestamp corrente
    }
    else
    {
        
    $time=mktime(0,0,0,$mese,1,$anno); //altrimenti mi ricavo il timestamp del primo giorno del mese richiesto
    }

        
    //utilizzo il sistema creato da PaTer in questo thread http://www.giorgiotave.it/forum/scripting-e-risorse-utili/3211-tutorial-creare-un-calendario-dinamico-php.html apportando alcune modifiche
        
    $dati['giorni_mesi'] =  array(31031303130313130313031); // Array con i giorni dei mesi
        
    $dati['mese_num'] = date("n",  $time); // Mese corrente ( numerico )
        
    $dati['mese_text'] = date("F"$time); // Mese Corrente ( testuale )
        
    $dati['anno'] = date("Y"$time); // Anno
        
    $dati['start'] = date("w"mktime(0,0,0$dati['mese_num'], 1$dati['anno'])); // Giorno della settimana del primo giorno del mese
        
    $dati['giorni_mesi'][1]=(date('L',$time)==0)?28:29// calcolo giorni mese di Febbraio
        
    $dati['giorni_mese'] = $dati['giorni_mesi'][$dati['mese_num']-1]; // Giorni del mese corrente
        
    $dati['settimana']=array("D","L","M","M","G","V","S");
        
    $prenotato=array("0"=>"0.png","1"=>"1p.png","2"=>"2p.png","3"=>"3p.png"); // prenotati ma non confermati avranno una colorazione gialla
        
    $confermato=array("0"=>"0.png","1"=>"1c.png","2"=>"2c.png","3"=>"3c.png"); // confermati avranno una colorazione rossa
        
    //procedo quindi a creare due form che mi portino al mese precedente ed al mese successivo a quello attualmente visualizzato facendo attenzione al cambio di anno, nel caso si stia visualizzando il mese di Gennaio il form del mese precedente mi dovrà postare il mese 12 e l'anno corrente -1. Speculare per il mese di dicembre, il form per il mese successivo dovrà postare il mese 1 e l'anno incrementato di 1    
    ?>
    <table border="0" width="100%">
        <tr>
            <td width="33%"><form action="<? echo $_SERVER['REQUEST_URI']; ?>" method="post"><input type="hidden" name="mese" value="<? if ($dati['mese_num']=="1") { echo "12";} else {echo $dati['mese_num']-1;} ?>" /><input type="hidden" name="anno" value="<? if ($dati['mese_num']=="1"){ echo $dati['anno']-1;} else {echo $dati['anno'];}?>" /><input type="submit" value="&nbsp;&lt;&nbsp;" /></form></td>
            <td width="33%"><? echo "Mese: <strong>".$dati['mese_text']."</strong> Anno: <strong>".$dati['anno'?></strong></td>
            <td width="33%"><form action="<? echo $_SERVER['REQUEST_URI']; ?>" method="post"><input type="hidden" name="mese" value="<? if ($dati['mese_num']=="12") { echo "1";} else {echo $dati['mese_num']+1;} ?>" /><input type="hidden" name="anno" value="<? if ($dati['mese_num']=="12"){ echo $dati['anno']+1;} else {echo $dati['anno'];}?>" /><input type="submit" value="&nbsp;&gt;&nbsp;" /></form></td>    
        </tr>
    </table>
    <table border="1"  class="calendario" align="center">
    <caption><strong>Calendario</strong></caption>
    <tr>
    <td rowspan="2">Stanze</td>
    <?
    // partita la tabella procedo alla costruzione delle righe di intestazione

    //$d servirà per verificare il ciclo dei giorni della settimana, evitando così di dover utilizzare una funzione ad ogni ciclo, basta fare un semplice controllo che una volta incrementato a 7 il valore di $d, questo riparta da 0
    $d=$dati['start'];     // indice della settimana del primo giorno del mese
        
    for ($i=1$i<=$dati['giorni_mese'];$i++)
        {
            if (
    $d=="7"$d=0;
        
    ?>    
            <td style="text-align:center;<? if ($d=="6" || $d=="0") echo "background-color:red;"// se $d è uguale a 6 o 0 vuol dire che è un sabato o una domenica, quindi coloriamo di rosso questi giorni ?>"><? echo $dati['settimana'][$d]; //utilizzo $d anche come indice progressivo per visualizzare il contenuto dell'array dei giorni della settimana ?></td>
        <?    
            $d
    ++; //ad ogni ciclo bisogna ovviamente incrementare $d
        
    }
        
    ?>
    </tr>
    <tr>
    <?
    // Esattamente come il ciclo precedente costruisco la riga dei giorni del mese
    $d=$dati['start'];    
        for (
    $i=1$i<=$dati['giorni_mese'];$i++)
        {
            if (
    $d=="7"$d=0;
        
    ?>    
            <td style="text-align:center;<? if ($d=="6" || $d=="0") echo "background-color:red;"?>"><? echo $i?></td>
        <?    
            $d
    ++;
        }
        
    ?>
    </tr>
    <?
    //procedo alla prima query per estrarre i nomi delle stanze
    $sql_stanze="SELECT * FROM stanze ORDER BY nome";
    $query_stanze=@mysql_query($sql_stanze) or die (mysql_error());
    while (
    $row_stanze=mysql_fetch_array($query_stanze)) // ed inizio a ciclare questo risultato
    {
        echo 
    "<tr><td class=\"name\">".$row_stanze['nome']."</td>";
        
    $startmonth=mktime(0,0,0,$dati['mese_num'],1,$dati['anno']); // mi valorizzo il timestamp del primo giorno del mese 
        
    $stopmonth=mktime(0,0,0,$dati['mese_num'],$dati['giorni_mese'],$dati['anno']); // e dell'ultimo giorno del mese
        //estraggo quindi le prenotazioni del mese corrente per questa stanza
        
    $sql_pren="SELECT * FROM prenotazioni WHERE id_stanza='".$row_stanze['id']."' AND ((datain < '$startmonth' AND dataout >= '$startmonth') OR (datain >='$startmonth' AND dataout <= '$stopmonth') OR (datain <= '$stopmonth' AND dataout > '$stopmonth')) ORDER BY datain";
        
    //il sistema utilizzato è quello di controllare se vi sono prenotazioni che iniziano il mese precedente e finiscono dopo il primo giorno del mese interessato, poi se vi sono prenotazioni che iniziano e finiscono entro il mese corrente e quindi se vi sono prenotazioni che iniziano prima del fine mese corrente e finiscono nel mese successivo
        
    $query_pren=@mysql_query($sql_pren) or die (mysql_error());

    //recuperati questi dati inizio a salvarmi i valori interessati dentro degli array il cui indice non è altro, per unicità, che il timestamp del giorno in questione, che ad ogni ciclo incremento di  1 giorno = 86400 secondi
    for ($i=$startmonth;$i<=$startmonth+(($dati['giorni_mese'])*86400);$i=$i+86400)    
    {
        
    $stanza[$i]=0;
        
    $stato[$i]=false;
        
    $nome[$i]=false;
    }    
        
    //recuperati questi dati inizio a salvarmi i valori interessati dentro degli array il cui indice non è altro, per unicità, che il timestamp del giorno in questione, che ad ogni ciclo incremento di  1 giorno = 86400 secondi. 
        
        // per poter distinguere le prenotazioni tra loro utilizzo il sistema di valorizzare cella per cella (giorno per giorno) l'array $stanza. Se il suo valore è uguale a 0 (verde) la stanza, quel giorno, è libera, se è uguale a 1 significa che è l'inizio o la fine della prenotazione, se è uguale a 2 vuol dire che la stanza è occupata per tutto il giorno, se è uguale a 3 vuol dire che quel giorno sono presenti un fine prenotazione ed un inizio prenotazione. Se il numero è maggiore (nero) significa che c'è qualcosa che non va. :)
        
    while ($row_pren=mysql_fetch_array($query_pren))
        {
            if (
    $row_pren['datain']<$startmonth && $row_pren['dataout']>$startmonth//se la prenotazione inizia il mese precedente e finisce dopo il primo giorno del mese
            
    {
                
    //estraggo il nominativo della prenotazione
                
    $sql_anagr="SELECT * FROM anagrafica WHERE id='".$row_pren['id_cliente']."'";
                
    $query_anagr=@mysql_query($sql_anagr) or die (mysql_error());
                
    $array_anagr=mysql_fetch_array($query_anagr);
                
                
                
    $q=$startmonth//parto dal primo giorno del mese, relativo alla stanza di cui si sta eseguendo il ciclo
                
    $stanza[$q]=$stanza[$q]+3
                
    $stato[$q]=$row_pren['stato'];  // valorizzo lo stato prenotato o confermato
                
    $id[$q]=$row_pren['id']; // valorizzo l'id della prenotazione
                
    $nome[$q]=$array_anagr['intestazione']; //valorizzo l'anagrafica del cliente
                
    $in[$q]=$row_pren['datain']; //valorizzo la data inizio prenotazione
                
    $out[$q]=$row_pren['dataout']; //valorizzo la data fine prenotazione
                
                
    for ($q=$startmonth+86400;$q<=$row_pren['dataout'];$q=$q+86400)
                {
                    if (
    $q<$row_pren['dataout'])
                    {
                        
    $stanza[$q]=$stanza[$q]+3;
                        
    $stato[$q]=$row_pren['stato'];
                        
    $id[$q]=$row_pren['id'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                    else
                    {
                        
    $stanza[$q]=$stanza[$q]+1;
                        
    $id[$q]=$row_pren['id'];
                        
    $stato[$q]=$row_pren['stato'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                }
            }
            else if (
    $row_pren['datain']>=$startmonth// se la data inizio prenotazione è maggiore del primo giorno del mese
            
    {
                
    //estraggo il nominativo della prenotazione
                
    $sql_anagr="SELECT * FROM anagrafica WHERE id='".$row_pren['id_cliente']."'";
                
    $query_anagr=@mysql_query($sql_anagr) or die (mysql_error());
                
    $array_anagr=mysql_fetch_array($query_anagr);
                
                
    $dw=date('d',$row_pren['datain']); //trovo il giorno del mese della data inizio
                
    $dw=$startmonth+(($dw-1)*86400); // e per regolarità sommo il timestamp di inizio mese al giorno del mese di data inizio prenotazione trasformato in secondi (sotratto di 1 perché il primo giorno è già valorizzato)
                
    $q=$dw;
                
    $stanza[$q]=$stanza[$q]+1// aumento di 1 il valore di $stanza
                
    $stato[$q]=$row_pren['stato'];
                
    $id[$q]=$row_pren['id'];
                
    $nome[$q]=$array_anagr['intestazione'];
                
    $in[$q]=$row_pren['datain'];
                
    $out[$q]=$row_pren['dataout'];
                
    // il sistema finora utilizzato, ovvero di incrementare i giorni sommando l'equivalente in secondi di un singolo giorno, va bene finché non ci si trova nei mesi in cui avviene il cambio dell'ora legale con quella solare e viceversa, ovvero ottobre e Marzo. Ma basta eseguire il controllo sulla data in questione ed eventualmente incrementare o decrementare il valore di 3600 secondi (1 ora)
                
    if (date("I",$row_pren['dataout'])==&& $dati['mese_num']==3) {$row_pren['dataout']=$row_pren['dataout']+3600;};
                if (
    date("I",$row_pren['dataout'])==&& $dati['mese_num']==10) {$row_pren['dataout']=$row_pren['dataout']-3600;};
                for (
    $q=($dw+86400);$q<=$row_pren['dataout'];$q=$q+86400)
                {
                    if (
    $q<$row_pren['dataout'])
                    {
                        
    $stanza[$q]=$stanza[$q]+3;
                        
    $stato[$q]=$row_pren['stato'];
                        
    $id[$q]=$row_pren['id'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                    else
                    {
                        
    $stanza[$q]=$stanza[$q]+1;
                        
    $stato[$q]=$row_pren['stato'];
                        
    $id[$q]=$row_pren['id'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                }
            }
            else if (
    $row_pren['dataout']=$startmonth// se la data di fine prenotazione è uguale al primo giorno del mese
            
    {
                
    $q=$startmonth;
                
    $stanza[$q]=$stanza[$q]+1;
                
    $stato[$q]=$row_pren['stato'];
                
    $id[$q]=$row_pren['id'];
                
    $nome[$q]=$array_anagr['intestazione'];
                
    $in[$q]=$row_pren['datain'];
                
    $out[$q]=$row_pren['dataout'];
            }
        }
    //a questo punto i nostri array son ben che popolati, possiamo quindi procedere alla costruzione della tabella
    $d=$dati['start'];
        
    for (
    $i=$startmonth;$i<=$startmonth+(($dati['giorni_mese']-1)*86400);$i=$i+86400)    
    {
        
    $vin=date('d-m-Y',$in[$i]);
        
    $vout=date('d-m-Y',$out[$i]);
        if (
    $d=="7")
        {
            
    $d=0;
        } 
        echo 
    "<td style=\"text-align:center;";
        if (
    $d=="0" || $d=="6"
        {
            echo 
    "border:1px solid #ff020e;"// per i Sabati e le Domeniche metto un bordo rosso alle celle della tabella
        
    }
        echo 
    "\">";
             if (
    $stanza[$i]=='0'// se il valore è uguale a zero e quindi la stanza è libera
            
    {
                echo 
    "<img src=\"image/0.png\" alt=\"\" />";
            }
            else if (
    $stanza[$i]=='1'// se il valore è uguale a 1 e quindi si tratta di un inizio prenotazione o un fine prenotazione
            
    {
                
    $back=($stato[$i]==0)?$prenotato['1']:$confermato['1']; // controllo se la prenotazione è confermata o meno
                
                //nella costruzione del link dell'immagine inserisco l'id della prenotazione per recuperare questo dato quando andrò nella pagina della prenotazione e come title del link metto i dati importanti della prenotazione "Prenotazione Mario Rossi dal 01/01/2010 al 06/01/2010"
                
    echo "<a href=\"prenotazioni.php?id=".$id[$i]."\" title=\"Prenotazione ".$nome[$i]." dal ".$vin." al ".$vout."\"><img src=\"image/".$back."\" alt=\"\" /></a>";
            }
            else if (
    $stanza[$i]=='2')  // se il valore è uguale a 2 e quindi la stanza è occupata tutta la giornata
            
    {
                
    $back=($stato[$i]==0)?$prenotato['2']:$confermato['2'];
                echo 
    "<a href=\"prenotazioni.php?id=".$id[$i]."\" title=\"Prenotazione ".$nome[$i]." dal ".$vin." al ".$vout."\"><img src=\"image/".$back."\" alt=\"\" /></a>";
            }
            else if (
    $stanza[$i]=='3'// se il valore è uguale a 3 e quindi abbiamo una fine prenotazione ed un inizio prenotazione lo stesso giorno
            
    {
                
    $back=($stato[$i]==0)?$prenotato['3']:$confermato['3'];
                echo 
    "<a href=\"prenotazioni.php?id=".$id[$i]."\" title=\"Prenotazione ".$nome[$i]." dal ".$vin." al ".$vout."\"><img src=\"image/".$back."\" alt=\"\" /></a>";
            }
            else 
    // se il valore è superiore a 3, e significa che qualcosa non va... :)
            
    {
                echo 
    "<img src=\"image/black.png\" alt=\"\" />";
            }
                
        echo 
    "</td>";
        
    $d++;
    }
    ?>
    </tr>
    <?
    }
    ?>
    </table>
    Il codice è validato XHTML 1.0 Transitional.

    Quì potrete valutare una demo (cercate il mese di Aprile 2010) e quì scaricare lo script completo come la demo.

    Per quanto concerne le tabelle è inutile che posti la struttura da me creata perché sarebbe inutilizzabile dato che fa parte di una applicazione più complessa. Sommariamente, per l'utilizzo di questo script, ci devono essere:

    • Una tabella "anagrafica" con un "id" Auto Increment ed il campo "intestazione" dove inserire il nome e cognome del cliente
    • Una tabella "stanze" che abbia un "id" Auto Increment ed il campo "nome" dove inserire il nome della stanza
    • Una tabella "prenotazioni" che abbia
      • "id" Auto Increment,
      • un campo "id_cliente" dove inserire l'id del cliente che sta prenotando,
      • un campo "id_stanza" dove inserire l'id della stanza prenotata,
      • un campo "datain" dove inserire il timestamp della data inizio prenotazione
      • un campo "dataout" dove inserire il timestamp della data fine prenotazione
      • un campo "stato" che sarà valorizzato 0 se la prenotazione non è confermata e 1 se invece lo è


    A tutto questo va poi aggiunto o modificato quanto necessario, io l'ho creato per la gestione di una struttura alberghiera ma si può benissimo adattare a qualsivoglia utilizzo similare.

    Spero vi sia utile, attendo comunque Vs. eventuali appunti o suggerimenti.

    Ciao!!
    Ultima modifica di Samyorn; 19-11-12 alle 22:37 Motivo: Aggiornato link allo script
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  2. #2
    User
    Data Registrazione
    May 2010
    Messaggi
    85
    Script molto utile e interessante, ottimo come base di partenza per poi sviluppare applicazioni più complesse... L'unica cosa è che segnala una serie di "Notice: Undefined variable" per quanto riguarda le variabili $in e $out, ma nonostante ciò funziona bene...

  3. #3
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Ciao ale87440 e grazie del commento

    Sicuramente si trova degli indici vuoti e quindi esce fuori i Notice.
    Per eliminarli o diminuisci il livello di Notice o con un paio di modifiche fai in modo di valorizzare comunque ogni indice che verrà analizzato dallo script.

    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  4. #4
    User Newbie
    Data Registrazione
    Jul 2010
    Messaggi
    1
    Ciao, sono da poco iscritto e volevo complimentarmi col lavoro che hai proposto.
    L'ho provato subito ma riscontro dei problemi e non so se sono miei errori...

    Nel DB i campi "data_inizio_periodo" e "data_fine_periodo" di che tipo devono essere? Timestamp?
    Dichiarandoli entrambi come timestamp se metto come "data_inizio_periodo" la data odierna e come "data_fine_periodo" sempre la data odierna o anche un altro giorno seguente non mi visualizza nessuna prenotazione!!

    Puoi darmi qualche suggerimento?
    Grazie in anticipo e complimenti comunque!

  5. #5
    User
    Data Registrazione
    May 2010
    Messaggi
    85
    Io ho semplicemente messo INT(11) come campo delle date, così da non avere alcun problema...

    Ciao...

  6. #6
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Salve ragazzi e benvenuto a koqu nel Forum GT.

    Si, tutti i campi data sono gestiti in formato timestamp, esattamente come ale87440 utilizzo dei campi INT.
    Per il tuo caso ho appena testato e funziona, guarda la demo: stanza 9 mese Aprile.
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  7. #7
    User Newbie
    Data Registrazione
    Sep 2010
    Messaggi
    2
    Ciao, ottimo lavoro, ho un problemino quando l'inizio della prenotazione è l'ultimo giorno del mese viene visualizzato libero mentre gli altri giorni della prenotazione sono corretti, cosa mi sfugge?
    Saluti.
    Ultima modifica di Samyorn; 30-09-10 alle 20:13 Motivo: Maiuscole e punteggiatura. ;)

  8. #8
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Ciao nerkyos e benvenuto nel Forum GT.

    Ho appena fatto dei test e a me non da problemi.
    Ti direi di verificare il valore del timestamp salvato come data inizio.
    Come puoi vedere anche nella demo ci sono vari casi di data inizio uguale all'ultimo giorno del mese e funzionano sia come prenotazione che come confermato.
    Facci sapere.
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  9. #9
    User Newbie
    Data Registrazione
    Sep 2010
    Messaggi
    2
    Si ho risolto grazie era un problema con il mysql.

    Saluti, buon lavoro.
    Ultima modifica di Samyorn; 04-10-10 alle 20:28 Motivo: Maiuscole e punteggiatura.

  10. #10
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Bene così, buon lavoro anche a te.
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  11. #11
    User Newbie
    Data Registrazione
    Jan 2011
    Località
    palermo
    Messaggi
    1

    Graz<ie

    Ti ringrazio per l'ottimo lavoro....da diverso tempo stavo elaborando una soluzione per fare questo planning per il mio software e sembra calato apposta sulle mie tabelle.

    Io ho fatto solo una modifica alla sql per gestire sia gli ospiti in casa che le prenotazioni facendo una union ed ho messo una funzione di modifca al campo in e out avendo messo d'appertutto nel mio db i campi come date e non timestamp.

    Ve la invio...chissa che non serva a qualcuno!!!

    SELECT *
    FROM (
    (
    SELECT `arrivi`.`id_ospiti` , `arrivi`.`id_prenotazioni` , `arrivi`.`id_arrivo` , `arrivi`.`stato` , `arrivi`.`tipo_camera0` , `arrivi`.`id_camera` , `arrivi`.`id_per_tipo_ospite` , `arrivi`.`tipo_ospite` , UNIX_TIMESTAMP( `arrivi`.`check_in` ) AS `check_in` , UNIX_TIMESTAMP( `arrivi`.`check_out` ) AS `check_out` , `arrivi`.`n_giorni`
    FROM `arrivi`
    WHERE `arrivi`.`id_camera` ='".$row_stanze['id_stanza']."'
    )
    UNION (
    SELECT `prenotazioni`.`id_ospiti` , `prenotazioni`.`id_prenotazioni` , `prenotazioni`.`id_arrivo` , `prenotazioni`.`stato` , `prenotazioni`.`tipo_camera0` , `prenotazioni`.`id_camera` , `prenotazioni`.`id_per_tipo_ospite` , `prenotazioni`.`tipo_ospite` , UNIX_TIMESTAMP( `prenotazioni`.`check_in` ) AS `check_in` , UNIX_TIMESTAMP( `prenotazioni`.`check_out` ) AS `check_out` , `prenotazioni`.`n_giorni`
    FROM `prenotazioni`
    WHERE `prenotazioni`.`id_camera` ='".$row_stanze['id_stanza']."'
    )
    ) AS Tabella
    WHERE ((check_in < '$startmonth' AND check_out >= '$startmonth') OR (check_in >='$startmonth' AND check_out <= '$stopmonth') OR (check_in <= '$stopmonth' AND check_out > '$stopmonth')) GROUP BY Tabella.id_per_tipo_ospite";

  12. #12
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Grazie Aleami77.

    Sarà sicuramente utile.
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  13. #13
    User Newbie
    Data Registrazione
    Sep 2009
    Messaggi
    1

    mesi in italiano

    $mesi["January"]="Gennaio";
    $mesi["February"]="Febbraio";
    $mesi["March"]="Marzo";
    $mesi["April"]="Aprile";
    $mesi["May"]="Maggio";
    $mesi["June"]="Giugno";
    $mesi["July"]="Luglio";
    $mesi["August"]="Agosto";
    $mesi["September"]="Settembre";
    $mesi["October"]="Ottobre";
    $mesi["November"]="Novembre";
    $mesi["December"]="Dicembre";

    $dati['mese_text'] = $mesi[date("F", $time)];

    a qualcuno magari poteva servire avere i mesi in italiano.
    Chi sa dirmi perchè la prima data prenotata mi si evidenzia mentre l'ultima rimane uguale alle date di mezzo?
    Inoltre vorrei poter cliccare sul calendario direttamente per poter inserire la prenotazione. QUalche idea?
    grazie

  14. #14
    User Newbie
    Data Registrazione
    Aug 2011
    Località
    Trento
    Messaggi
    1
    Ciao a tutti,

    ho scaricato questo script e lo trovo fantastico. Sarebbe possibile avere la struttura delle tabelle interessate?

  15. #15
    User Newbie
    Data Registrazione
    Apr 2011
    Località
    Firenze
    Messaggi
    1

    Calendario prenotazioni

    buon dì,
    sono contentissimo di aver trovato il tuo script , molto utile per il mo progetto, l'unico problema che riscontro è che non mi cambia i colori nelle celle quando inserisco le date datain/dataout. Campo mysql(tipo datatime), Es in 2011-08-20 out 2011-08-18, nel form delle prenotazioni le celle mi rimangono tutte verdi, è cone se non riconoscesse le date inserite sarei molto grato se mi potessi aiutare a risolverlo.
    complimenti per lo script

  16. #16
    User Newbie
    Data Registrazione
    Aug 2011
    Località
    Trento
    Messaggi
    2
    Ciao a tutti,

    sono un nuovo iscritto e ho un problema con lo script oggetto di questo post. Premetto che ho scaricato il file zip e l'ho testato trovandolo altamente funzionale.

    Io però lo vorrei adattare alla mia situazione: quella di un autonoleggio. A differenza del caso dell'albergo (in cui al posto delle stanze ho le auto) non so come fare per adattare il mio database mysql allo script.

    Questo è il dump relativo alle mie tabelle:

    Codice PHP:
    TABELLA NOLEGGIO

    CREATE TABLE 
    IF NOT EXISTS `noleggio` (
      `
    contrattobigint(50NOT NULL auto_increment,
      `
    data_contrattodate NOT NULL,
      `
    data_iniziodate NOT NULL,
      `
    data_finedate NOT NULL,
      `
    clientevarchar(255NOT NULL,
      `
    flottavarchar(255NOT NULL,
      `
    conducentitext,
      `
    costo_giornalierodecimal(10,2NOT NULL,
      `
    costo_totaledecimal(10,2NOT NULL,
      `
    sanzione_giornalieradecimal(10,2NOT NULL,
      `
    giorni_totalevarchar(5NOT NULL,
      
    PRIMARY KEY  (`contratto`)
    ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=;


    TABELLA FLOTTA

    CREATE TABLE 
    IF NOT EXISTS `flotta` (
      `
    idbigint(50NOT NULL auto_increment,
      `
    targavarchar(7) default NULL,
      `
    telaiovarchar(255) default NULL,
      `
    modellovarchar(150) default NULL,
      `
    versionevarchar(255) default NULL,
      `
    colorevarchar(100) default NULL,
      `
    lungo_periodotinyint(1) default NULL,
      `
    kmvarchar(10) default NULL,
      `
    carburantevarchar(20) default NULL,
      `
    kwvarchar(10) default NULL,
      `
    cvvarchar(10) default NULL,
      `
    cilindratavarchar(10) default NULL,
      `
    data_immatricolazionevarchar(10) default NULL,
      `
    categoriavarchar(255NOT NULL,
      
    PRIMARY KEY  (`id`),
      
    UNIQUE KEY `telaio` (`telaio`),
      
    UNIQUE KEY `targa` (`targa`)
    ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=;


    TABELLA CLIENTI

    CREATE TABLE 
    IF NOT EXISTS `clienti` (
      `
    idbigint(50NOT NULL auto_increment,
      `
    ragione_socialevarchar(255NOT NULL,
      `
    viavarchar(255NOT NULL,
      `
    numerovarchar(5NOT NULL,
      `
    capvarchar(5NOT NULL,
      `
    cittavarchar(255NOT NULL,
      `
    provinciavarchar(5NOT NULL,
      `
    cellularevarchar(15NOT NULL,
      `
    emailvarchar(255NOT NULL,
      `
    partita_ivavarchar(15NOT NULL,
      `
    codice_fiscalevarchar(15NOT NULL,
      `
    pagamentovarchar(255) default NULL,
      
    PRIMARY KEY  (`id`)
    ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=
    Da notare che non ho una tabella prenotazioni e quindi non so come poter adattare il tutto al mio caso.

    Mi sapete dare una traccia?

  17. #17
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Ciao a tutti,
    intanto mi scuso per il ritardo nel rispondervi, ho avuto un po' di mesi abbastanza incasinati.

    Vediamo se possiamo risolvere qualche problema.

    Citazione Originariamente Scritto da creatorweb Visualizza Messaggio
    Chi sa dirmi perchè la prima data prenotata mi si evidenzia mentre l'ultima rimane uguale alle date di mezzo?
    Ciao Creatorweb.
    Prova a fare un vardump dell'array in questione e verifica che combaci con il timestamp della data di check-out. Ad occhio sembra che sia maggiore quindi lo interpreta come "giorno di mezzo". Se è solo un caso, potresti postare la data interessata? Se è per tutte le casistiche c'è qualcosa che non va, come vedi nella demo non crea alcun problema.
    Citazione Originariamente Scritto da creatorweb Visualizza Messaggio
    Inoltre vorrei poter cliccare sul calendario direttamente per poter inserire la prenotazione. QUalche idea?
    grazie
    Personalmente, esattamente come è stato inserito il link per i periodi prenotati, quindi basta che vedi lo script di costruzione, mi linko dalle caselle in verde alla pagina di inserimento prenotazione portandomi dietro il timestamp del giorno dove ho cliccato e l'id della stanza, così mi trovo già due campi compilati.

    P.S. Grazie per i Mesi in Italiano
    Citazione Originariamente Scritto da Nemo81 Visualizza Messaggio
    Ciao a tutti,

    ho scaricato questo script e lo trovo fantastico. Sarebbe possibile avere la struttura delle tabelle interessate?
    Grazie Nemo81.

    Nel primo post trovi la struttura base delle tabelle da creare per l'utilizzo dello script.
    Citazione Originariamente Scritto da maripas Visualizza Messaggio
    buon dì,
    sono contentissimo di aver trovato il tuo script , molto utile per il mo progetto, l'unico problema che riscontro è che non mi cambia i colori nelle celle quando inserisco le date datain/dataout. Campo mysql(tipo datatime), Es in 2011-08-20 out 2011-08-18, nel form delle prenotazioni le celle mi rimangono tutte verdi, è cone se non riconoscesse le date inserite sarei molto grato se mi potessi aiutare a risolverlo.
    complimenti per lo script
    Ciao maripas.
    L'intero script è sviluppato con date in formato timestamp, come vedi scritto anche nel primo post, pertanto non potrai mai trovar corrispondenza tra l'indice dell'array (in timestamp 1313020800) ed il valore della data (in datetime 2011-08-20).

    Citazione Originariamente Scritto da Neo996sps Visualizza Messaggio
    Io però lo vorrei adattare alla mia situazione: quella di un autonoleggio. A differenza del caso dell'albergo (in cui al posto delle stanze ho le auto) non so come fare per adattare il mio database mysql allo script.
    Ciao Neo996sps.

    La struttura di base non cambia, diciamo, anche se nel caso di noleggio hai dei controlli in più da fare.
    Mentre in una struttura alberghiera i check-out si fanno entro un certo orario (supponiamo le 11) ed i check-in dopo almeno un'ora (supponiamo le 12), nel caso dell'autonoleggio queste certezze non ci sono, quindi dovrai inserire dei controlli specifici sugli orari, almeno nei giorni in cui ti si accavalla un out ed un in per la stessa macchina. Il controllo lo immetterei all'atto dell'inserimento della nuova prenotazione.
    Fantastico sarebbe inserire dei controlli Ajax che alla selezione di macchina data uscita e data rientro ti dica nell'immediato se ti stai accavallando ad altre prenotazioni o meno e se hai, o meno, problemi sull'orario di uno dei due giorni rispetto ad altre prenotazioni. Esempio ti spunti una nota: La vettura AA000AA giorno xx-xx-xxxx rientra dal noleggio alle ore 15.00, cosi sai che quella macchina non potrai di certo noleggiarla per orari precedenti e forse neanche successivi conoscendo i clienti ma queste sono considerazioni che deve fare l'essere umano almenocché non si stabilisca che di default, sempre a mo di esempio, una macchina non è disponibile prima di 2 ore successive al rientro previsto dal noleggio precedente così prevedi il ritardo del cliente e gli eventuali espletamenti di lavaggio, refuelling ed altro.
    Ma se manca Ajax gli stessi controlli si possono fare anche tramite PHP, ma sarà meno figo




    Spero di esservi stato d'aiuto.
    A presto
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  18. #18
    User Newbie
    Data Registrazione
    Aug 2011
    Località
    Trento
    Messaggi
    2
    Ciao,

    io ancora non riesco ad adattare lo script alle mie esigenze. Si può avere il dump del database che sfrutta la demo del primo post?

  19. #19
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Ciao Neo996sps,
    la struttura è molto banale, ti riporto quanto indicato nel primo post.
    Citazione Originariamente Scritto da Samyorn Visualizza Messaggio
    Per quanto concerne le tabelle è inutile che posti la struttura da me creata perché sarebbe inutilizzabile dato che fa parte di una applicazione più complessa. Sommariamente, per l'utilizzo di questo script, ci devono essere:

    • Una tabella "anagrafica" con un "id" Auto Increment ed il campo "intestazione" dove inserire il nome e cognome del cliente
    • Una tabella "stanze" che abbia un "id" Auto Increment ed il campo "nome" dove inserire il nome della stanza
    • Una tabella "prenotazioni" che abbia
      • "id" Auto Increment,
      • un campo "id_cliente" dove inserire l'id del cliente che sta prenotando,
      • un campo "id_stanza" dove inserire l'id della stanza prenotata,
      • un campo "datain" dove inserire il timestamp della data inizio prenotazione
      • un campo "dataout" dove inserire il timestamp della data fine prenotazione
      • un campo "stato" che sarà valorizzato 0 se la prenotazione non è confermata e 1 se invece lo è

    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  20. #20
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Quì il dump del database della demo:
    Codice:
    --
    -- Struttura della tabella `anagrafica`
    --
    
    CREATE TABLE IF NOT EXISTS `anagrafica` (
      `id` int(100) NOT NULL AUTO_INCREMENT,
      `intestazione` varchar(255) NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;
    
    --
    -- Dump dei dati per la tabella `anagrafica`
    --
    
    INSERT INTO `anagrafica` (`id`, `intestazione`) VALUES
    (1, 'Samyorn'),
    (2, 'Forum GT');
    
    -- --------------------------------------------------------
    
    
    --
    -- Struttura della tabella `prenotazioni`
    --
    
    CREATE TABLE IF NOT EXISTS `prenotazioni` (
      `id` int(255) NOT NULL AUTO_INCREMENT,
      `id_cliente` int(11) NOT NULL,
      `id_stanza` int(11) NOT NULL,
      `datain` int(11) NOT NULL,
      `dataout` int(11) NOT NULL,
      `stato` int(11) NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=18 ;
    
    --
    -- Dump dei dati per la tabella `prenotazioni`
    --
    
    INSERT INTO `prenotazioni` (`id`, `id_cliente`, `id_stanza`, `datain`, `dataout`, `stato`) VALUES
    (1, 1, 2, 1271109600, 1272492000, 1),
    (2, 2, 4, 1267052400, 1267398000, 0),
    (3, 1, 6, 1269986400, 1270159200, 1),
    (4, 1, 6, 1269126000, 1269986400, 0),
    (5, 2, 2, 1267398000, 1268434800, 0),
    (6, 1, 9, 1267743600, 1268866800, 1),
    (7, 1, 5, 1271541600, 1272578400, 1),
    (8, 2, 4, 1267743600, 1268866800, 1),
    (9, 1, 5, 1270677600, 1271541600, 0),
    (10, 2, 6, 1270504800, 1270850400, 1),
    (11, 1, 8, 1270850400, 1271628000, 0),
    (12, 2, 9, 1272060000, 1272751200, 0),
    (13, 1, 4, 1287525600, 1288476000, 1),
    (14, 2, 7, 1285884000, 1287180000, 0),
    (15, 1, 3, 1292022000, 1292108400, 1),
    (16, 2, 7, 1292108400, 1292799600, 0),
    (17, 1, 3, 1293145200, 1293922800, 1);
    
    -- --------------------------------------------------------
    
    --
    -- Struttura della tabella `stanze`
    --
    
    CREATE TABLE IF NOT EXISTS `stanze` (
      `id` int(100) NOT NULL AUTO_INCREMENT,
      `nome` varchar(100) NOT NULL,
      PRIMARY KEY (`id`),
      UNIQUE KEY `nome` (`nome`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=10 ;
    
    --
    -- Dump dei dati per la tabella `stanze`
    --
    
    INSERT INTO `stanze` (`id`, `nome`) VALUES
    (1, 'Stanza1'),
    (2, 'Stanza2'),
    (3, 'Stanza3'),
    (4, 'Stanza4'),
    (5, 'Stanza5'),
    (6, 'Stanza6'),
    (7, 'Stanza7'),
    (8, 'Stanza8'),
    (9, 'Stanza9');
    
    -- --------------------------------------------------------
    Spero ti sia utile.
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  21. #21
    User Newbie L'avatar di Dottor_Pimpernel
    Data Registrazione
    Jan 2012
    Località
    Vecchia Romagna
    Messaggi
    2
    Ciao sono nuovo del forum!
    Ho trovato questo forum proprio perchè stavo cercando uno script come questo da utilizzare per un esame di base di dati. E questo è perfetto!
    Premetto che sul php/sql non ho molta esperienza e mi sto avvicinando adesso proprio per motivi di studio... per cui portate pazienza se scrivo boiate o chiedo cose ovvie...

    Ho provato a lanciare lo script dall'archivio linkato in prima pagina ed utilizzando come prova il DB postato nel dump precedente, ma invece che girare liscio mi ritorna:

    Notice: Undefined index: mese in C:\Program Files (x86)\EasyPHP-5.3.8.1\www\calendar\index.php on line 32

    Notice: Undefined index: anno in C:\Program Files (x86)\EasyPHP-5.3.8.1\www\calendar\index.php on line 33

    e poi diseguito mi scrive come testo il codice dalla linea 97 circa fino alla fine...

    Il collegamento al DB avviene in maniera corretta (passa i controlli iniziali), probabilmente è una stupidaggine, ma non riesco proprio a venirne a capo...

  22. #22
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Ciao Dottor_Pimpernel e benvenuto nel Forum GT.

    Prova a sostituire il file index.php con questo:
    Codice PHP:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="it" lang="it">
    <head>
    <link rel="stylesheet" href="style/style.css" type="text/css" />
    <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
    <title>Forum GT - Calendario</title>
    </head>
    <body>
    <div id="contenitore_generale">
    <div id="header"><div id="testata"><h1>Gruppo di sviluppo del Forum GT</h1></div></div>
    <div id="demo"><h2>Script per creazione calendario prenotazioni.</h2></div>
    <div id="logo">
        <a href="http://www.giorgiotave.it/forum/" target="_blank"><img src="http://demogt.netsons.org/calendario/image/logo.png" alt="Logo Forum GT" title="Logo del Forum GT" /></a> 
        <a href="http://samyorn.giorgiotave.it/gruppi/115-PHP-Project/" target="_blank"><img src="http://demogt.netsons.org/newsdb/news/php-mysql_project.jpg" alt="Logo progetto PHP-MySQL" title="Logo del gruppo di sviluppo aree PHP-MySQL del Network GT" /></a>
    </div>
    <h1>Troverai dei dati gia inseriti nei mesi di Marzo-Aprile 2010. ;-)</h1>
    <?php
    //inseriamo i parametri di connessione al Database
    $db_host "indirizzo_server_mysql";
    $db_user "nomeutentemysql";
    $db_pass "passwordmysql";
    $db_name "nomedatabase";

    $connection = @mysql_connect($db_host,$db_user,$db_pass)
        or die (
    "Connessione al server non stabilita");
    $db = @mysql_select_db($db_name,$connection)
        or die (
    "Connessione al Db non stabilita");

    //Se cambio mese procedo al recupero dei dati postati.
    $mese="";
    $anno="";
    if (isset(
    $_POST['mese']))
    {
        
    $mese=$_POST['mese'];
        
    $anno=$_POST['anno'];
        
    $time=mktime(0,0,0,$mese,1,$anno); //altrimenti mi ricavo il timestamp del primo giorno del mese richiesto
    }
    else
    {
        
    $time=time();
    }


        
    //utilizzo il sistema creato da PaTer in questo thread http://www.giorgiotave.it/forum/scripting-e-risorse-utili/3211-tutorial-creare-un-calendario-dinamico-php.html apportando alcune modifiche
        
    $dati['giorni_mesi'] =  array(31031303130313130313031); // Array con i giorni dei mesi
        
    $dati['mese_num'] = date("n",  $time); // Mese corrente ( numerico )
        
    $dati['mese_text'] = date("F"$time); // Mese Corrente ( testuale )
        
    $dati['anno'] = date("Y"$time); // Anno
        
    $dati['start'] = date("w"mktime(0,0,0$dati['mese_num'], 1$dati['anno'])); // Giorno della settimana del primo giorno del mese
        
    $dati['giorni_mesi'][1]=(date('L',$time)==0)?28:29// calcolo giorni mese di Febbraio
        
    $dati['giorni_mese'] = $dati['giorni_mesi'][$dati['mese_num']-1]; // Giorni del mese corrente
        
    $dati['settimana']=array("D","L","M","M","G","V","S");
        
    $prenotato=array("0"=>"0.png","1"=>"1p.png","2"=>"2p.png","3"=>"3p.png"); // prenotati ma non confermati avranno una colorazione gialla
        
    $confermato=array("0"=>"0.png","1"=>"1c.png","2"=>"2c.png","3"=>"3c.png"); // confermati avranno una colorazione rossa
        
    //procedo quindi a creare due form che mi portino al mese precedente ed al mese successivo a quello attualmente visualizzato facendo attenzione al cambio di anno, nel caso si stia visualizzando il mese di Gennaio il form del mese precedente mi dovr‡ postare il mese 12 e l'anno corrente -1. Speculare per il mese di dicembre, il form per il mese successivo dovr‡ postare il mese 1 e l'anno incrementato di 1    
    ?>
    <table border="0" width="100%">
        <tr>
            <td width="33%"><form action="<?php echo $_SERVER['REQUEST_URI']; ?>" method="post"><input type="hidden" name="mese" value="<?php if ($dati['mese_num']=="1") { echo "12";} else {echo $dati['mese_num']-1;} ?>" /><input type="hidden" name="anno" value="<?php if ($dati['mese_num']=="1"){ echo $dati['anno']-1;} else {echo $dati['anno'];}?>" /><input type="submit" value="&nbsp;&lt;&nbsp;" /></form></td>
            <td width="33%"><?php echo "Mese: <strong>".$dati['mese_text']."</strong> Anno: <strong>".$dati['anno'?></strong></td>
            <td width="33%"><form action="<?php echo $_SERVER['REQUEST_URI']; ?>" method="post"><input type="hidden" name="mese" value="<?php if ($dati['mese_num']=="12") { echo "1";} else {echo $dati['mese_num']+1;} ?>" /><input type="hidden" name="anno" value="<?php if ($dati['mese_num']=="12"){ echo $dati['anno']+1;} else {echo $dati['anno'];}?>" /><input type="submit" value="&nbsp;&gt;&nbsp;" /></form></td>    
        </tr>
    </table>
    <table border="1"  class="calendario" align="center">
    <caption><strong>Calendario</strong></caption>
    <tr>
    <td rowspan="2">Stanze</td>
    <?php
    // partita la tabella procedo alla costruzione delle righe di intestazione

    //$d servir‡ per verificare il ciclo dei giorni della settimana, evitando cosÏ di dover utilizzare una funzione ad ogni ciclo, basta fare un semplice controllo che una volta incrementato a 7 il valore di $d, questo riparta da 0
    $d=$dati['start'];     // indice della settimana del primo giorno del mese
        
    for ($i=1$i<=$dati['giorni_mese'];$i++)
        {
            if (
    $d=="7"$d=0;
        
    ?>    
            <td style="text-align:center;<?php if ($d=="6" || $d=="0") echo "background-color:red;"// se $d Ë uguale a 6 o 0 vuol dire che Ë un sabato o una domenica, quindi coloriamo di rosso questi giorni ?>"><?php echo $dati['settimana'][$d]; //utilizzo $d anche come indice progressivo per visualizzare il contenuto dell'array dei giorni della settimana ?></td>
        <?php    
            $d
    ++; //ad ogni ciclo bisogna ovviamente incrementare $d
        
    }
        
    ?>
    </tr>
    <tr>
    <?php
    // Esattamente come il ciclo precedente costruisco la riga dei giorni del mese
    $d=$dati['start'];    
        for (
    $i=1$i<=$dati['giorni_mese'];$i++)
        {
            if (
    $d=="7"$d=0;
        
    ?>    
            <td style="text-align:center;<?php if ($d=="6" || $d=="0") echo "background-color:red;"?>"><?php echo $i?></td>
        <?php    
            $d
    ++;
        }
        
    ?>
    </tr>
    <?php
    //procedo alla prima query per estrarre i nomi delle stanze
    $sql_stanze="SELECT * FROM stanze ORDER BY nome";
    $query_stanze=@mysql_query($sql_stanze) or die (mysql_error());
    while (
    $row_stanze=mysql_fetch_array($query_stanze)) // ed inizio a ciclare questo risultato
    {
        echo 
    "<tr><td class=\"name\">".$row_stanze['nome']."</td>";
        
    $startmonth=mktime(0,0,0,$dati['mese_num'],1,$dati['anno']); // mi valorizzo il timestamp del primo giorno del mese 
        
    $stopmonth=mktime(0,0,0,$dati['mese_num'],$dati['giorni_mese'],$dati['anno']); // e dell'ultimo giorno del mese
        //estraggo quindi le prenotazioni del mese corrente per questa stanza
        
    $sql_pren="SELECT * FROM prenotazioni WHERE id_stanza='".$row_stanze['id']."' AND ((datain < '$startmonth' AND dataout >= '$startmonth') OR (datain >='$startmonth' AND dataout <= '$stopmonth') OR (datain <= '$stopmonth' AND dataout > '$stopmonth')) ORDER BY datain";
        
    //il sistema utilizzato Ë quello di controllare se vi sono prenotazioni che iniziano il mese precedente e finiscono dopo il primo giorno del mese interessato, poi se vi sono prenotazioni che iniziano e finiscono entro il mese corrente e quindi se vi sono prenotazioni che iniziano prima del fine mese corrente e finiscono nel mese successivo
        
    $query_pren=@mysql_query($sql_pren) or die (mysql_error());

    //recuperati questi dati inizio a salvarmi i valori interessati dentro degli array il cui indice non Ë altro, per unicit‡, che il timestamp del giorno in questione, che ad ogni ciclo incremento di  1 giorno = 86400 secondi
    for ($i=$startmonth;$i<=$startmonth+(($dati['giorni_mese'])*86400);$i=$i+86400)    
    {
        
    $stanza[$i]=0;
        
    $stato[$i]=false;
        
    $nome[$i]=false;
    }    
        
    //recuperati questi dati inizio a salvarmi i valori interessati dentro degli array il cui indice non Ë altro, per unicit‡, che il timestamp del giorno in questione, che ad ogni ciclo incremento di  1 giorno = 86400 secondi. 
        
        // per poter distinguere le prenotazioni tra loro utilizzo il sistema di valorizzare cella per cella (giorno per giorno) l'array $stanza. Se il suo valore Ë uguale a 0 (verde) la stanza, quel giorno, Ë libera, se Ë uguale a 1 significa che Ë l'inizio o la fine della prenotazione, se Ë uguale a 2 vuol dire che la stanza Ë occupata per tutto il giorno, se Ë uguale a 3 vuol dire che quel giorno sono presenti un fine prenotazione ed un inizio prenotazione. Se il numero Ë maggiore (nero) significa che c'Ë qualcosa che non va. :)
        
    while ($row_pren=mysql_fetch_array($query_pren))
        {
            if (
    $row_pren['datain']<$startmonth && $row_pren['dataout']>$startmonth//se la prenotazione inizia il mese precedente e finisce dopo il primo giorno del mese
            
    {
                
    //estraggo il nominativo della prenotazione
                
    $sql_anagr="SELECT * FROM anagrafica WHERE id='".$row_pren['id_cliente']."'";
                
    $query_anagr=@mysql_query($sql_anagr) or die (mysql_error());
                
    $array_anagr=mysql_fetch_array($query_anagr);
                
                
                
    $q=$startmonth//parto dal primo giorno del mese, relativo alla stanza di cui si sta eseguendo il ciclo
                
    $stanza[$q]=$stanza[$q]+3
                
    $stato[$q]=$row_pren['stato'];  // valorizzo lo stato prenotato o confermato
                
    $id[$q]=$row_pren['id']; // valorizzo l'id della prenotazione
                
    $nome[$q]=$array_anagr['intestazione']; //valorizzo l'anagrafica del cliente
                
    $in[$q]=$row_pren['datain']; //valorizzo la data inizio prenotazione
                
    $out[$q]=$row_pren['dataout']; //valorizzo la data fine prenotazione
                
                
    for ($q=$startmonth+86400;$q<=$row_pren['dataout'];$q=$q+86400)
                {
                    if (
    $q<$row_pren['dataout'])
                    {
                        
    $stanza[$q]=$stanza[$q]+3;
                        
    $stato[$q]=$row_pren['stato'];
                        
    $id[$q]=$row_pren['id'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                    else
                    {
                        
    $stanza[$q]=$stanza[$q]+1;
                        
    $id[$q]=$row_pren['id'];
                        
    $stato[$q]=$row_pren['stato'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                }
            }
            else if (
    $row_pren['datain']>=$startmonth// se la data inizio prenotazione Ë maggiore del primo giorno del mese
            
    {
                
    //estraggo il nominativo della prenotazione
                
    $sql_anagr="SELECT * FROM anagrafica WHERE id='".$row_pren['id_cliente']."'";
                
    $query_anagr=@mysql_query($sql_anagr) or die (mysql_error());
                
    $array_anagr=mysql_fetch_array($query_anagr);
                
                
    $dw=date('d',$row_pren['datain']); //trovo il giorno del mese della data inizio
                
    $dw=$startmonth+(($dw-1)*86400); // e per regolarit‡ sommo il timestamp di inizio mese al giorno del mese di data inizio prenotazione trasformato in secondi (sotratto di 1 perchÈ il primo giorno Ë gi‡ valorizzato)
                
    $q=$dw;
                
    $stanza[$q]=$stanza[$q]+1// aumento di 1 il valore di $stanza
                
    $stato[$q]=$row_pren['stato'];
                
    $id[$q]=$row_pren['id'];
                
    $nome[$q]=$array_anagr['intestazione'];
                
    $in[$q]=$row_pren['datain'];
                
    $out[$q]=$row_pren['dataout'];
                
    // il sistema finora utilizzato, ovvero di incrementare i giorni sommando l'equivalente in secondi di un singolo giorno, va bene finchÈ non ci si trova nei mesi in cui avviene il cambio dell'ora legale con quella solare e viceversa, ovvero ottobre e Marzo. Ma basta eseguire il controllo sulla data in questione ed eventualmente incrementare o decrementare il valore di 3600 secondi (1 ora)
                
    if (date("I",$row_pren['dataout'])==&& $dati['mese_num']==3) {$row_pren['dataout']=$row_pren['dataout']+3600;};
                if (
    date("I",$row_pren['dataout'])==&& $dati['mese_num']==10) {$row_pren['dataout']=$row_pren['dataout']-3600;};
                for (
    $q=($dw+86400);$q<=$row_pren['dataout'];$q=$q+86400)
                {
                    if (
    $q<$row_pren['dataout'])
                    {
                        
    $stanza[$q]=$stanza[$q]+3;
                        
    $stato[$q]=$row_pren['stato'];
                        
    $id[$q]=$row_pren['id'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                    else
                    {
                        
    $stanza[$q]=$stanza[$q]+1;
                        
    $stato[$q]=$row_pren['stato'];
                        
    $id[$q]=$row_pren['id'];
                        
    $nome[$q]=$array_anagr['intestazione'];
                        
    $in[$q]=$row_pren['datain'];
                        
    $out[$q]=$row_pren['dataout'];
                    }
                }
            }
            else if (
    $row_pren['dataout']=$startmonth// se la data di fine prenotazione Ë uguale al primo giorno del mese
            
    {
                
    $q=$startmonth;
                
    $stanza[$q]=$stanza[$q]+1;
                
    $stato[$q]=$row_pren['stato'];
                
    $id[$q]=$row_pren['id'];
                
    $nome[$q]=$array_anagr['intestazione'];
                
    $in[$q]=$row_pren['datain'];
                
    $out[$q]=$row_pren['dataout'];
            }
        }
    //a questo punto i nostri array son ben che popolati, possiamo quindi procedere alla costruzione della tabella
    $d=$dati['start'];
        
    for (
    $i=$startmonth;$i<=$startmonth+(($dati['giorni_mese']-1)*86400);$i=$i+86400)    
    {
        
    $vin=date('d-m-Y',$in[$i]);
        
    $vout=date('d-m-Y',$out[$i]);
        if (
    $d=="7")
        {
            
    $d=0;
        } 
        echo 
    "<td style=\"text-align:center;";
        if (
    $d=="0" || $d=="6"
        {
            echo 
    "border:1px solid #ff020e;"// per i Sabati e le Domeniche metto un bordo rosso alle celle della tabella
        
    }
        echo 
    "\">";
             if (
    $stanza[$i]=='0'// se il valore Ë uguale a zero e quindi la stanza Ë libera
            
    {
                echo 
    "<img src=\"image/0.png\" alt=\"\" />";
            }
            else if (
    $stanza[$i]=='1'// se il valore Ë uguale a 1 e quindi si tratta di un inizio prenotazione o un fine prenotazione
            
    {
                
    $back=($stato[$i]==0)?$prenotato['1']:$confermato['1']; // controllo se la prenotazione Ë confermata o meno
                
                //nella costruzione del link dell'immagine inserisco l'id della prenotazione per recuperare questo dato quando andrÚ nella pagina della prenotazione e come title del link metto i dati importanti della prenotazione "Prenotazione Mario Rossi dal 01/01/2010 al 06/01/2010"
                
    echo "<a href=\"prenotazioni.php?id=".$id[$i]."\" title=\"Prenotazione ".$nome[$i]." dal ".$vin." al ".$vout."\"><img src=\"image/".$back."\" alt=\"\" /></a>";
            }
            else if (
    $stanza[$i]=='2')  // se il valore Ë uguale a 2 e quindi la stanza Ë occupata tutta la giornata
            
    {
                
    $back=($stato[$i]==0)?$prenotato['2']:$confermato['2'];
                echo 
    "<a href=\"prenotazioni.php?id=".$id[$i]."\" title=\"Prenotazione ".$nome[$i]." dal ".$vin." al ".$vout."\"><img src=\"image/".$back."\" alt=\"\" /></a>";
            }
            else if (
    $stanza[$i]=='3'// se il valore Ë uguale a 3 e quindi abbiamo una fine prenotazione ed un inizio prenotazione lo stesso giorno
            
    {
                
    $back=($stato[$i]==0)?$prenotato['3']:$confermato['3'];
                echo 
    "<a href=\"prenotazioni.php?id=".$id[$i]."\" title=\"Prenotazione ".$nome[$i]." dal ".$vin." al ".$vout."\"><img src=\"image/".$back."\" alt=\"\" /></a>";
            }
            else 
    // se il valore Ë superiore a 3, e significa che qualcosa non va... :)
            
    {
                echo 
    "<img src=\"image/black.png\" alt=\"\" />";
            }
                
        echo 
    "</td>";
        
    $d++;
    }
    ?>
    </tr>
    <?php
    }
    ?>
    </table>
    <div id="footer">Special thanks to: <a href="http://samyorn.giorgiotave.it" target="_blank">Samyorn</a>.</div>
    </div>
    </body>
    </html>
    Con la modifica fatta alle righe 32 e 33 dovrebbe eliminarti gli E_NOTICE, per il resto credo che gli davano fastidio gli short-tag <? che nelle ultime versioni sono ritenuti obsoleti e dovresti attivarli tu manualmente, ma meglio evitare.

    Non ho testato, facci sapere se funziona.

    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  23. #23
    User Newbie L'avatar di Dottor_Pimpernel
    Data Registrazione
    Jan 2012
    Località
    Vecchia Romagna
    Messaggi
    2
    Ciao Samyorn, grazie mille!!
    Adesso gira senza problemi

  24. #24
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Magnifico!

    Buon lavoro allora.
    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  25. #25
    User Newbie
    Data Registrazione
    Nov 2012
    Località
    Firenze
    Messaggi
    1
    Salve,
    Ho visto lo script, ho creato le tabelle nel ma non fa scaricare lo script. Come posso scaricarlo visto che i commenti ne parlano molto bene?
    Grazie anticipatamente

  26. #26
    Consiglio Direttivo L'avatar di Samyorn
    Data Registrazione
    Dec 2007
    Località
    Catania
    Messaggi
    5,916
    Segui Samyorn su Twitter Aggiungi Samyorn su Google+ Aggiungi Samyorn su Facebook Aggiungi Samyorn su Linkedin
    Ciao Leonardo e Benvenuto nel Forum GT.

    Ho sistemato il link per scaricare lo script.

    MODFunzioni di PHP Qui, Quo, Qua
    Si parla poco di SMF? Sentiamo l'opinione di chi lo ha provato. Ti amo...brindiAMO?
    Conosci GTLab? Devi scegliere un CMS per Forum e non sai quale? Guarda quì!!

  27. #27
    User Newbie
    Data Registrazione
    May 2012
    Località
    Napoli
    Messaggi
    4
    Ciao ho provato il tuo script in locale, copiato e incollato il codice nel forum, ma mi da questo seguente errore:

    Notice: Undefined variable: in in C:\xampp\htdocs\prenotazioneTest\index.php on line 219

    Notice: Undefined variable: out in C:\xampp\htdocs\prenotazioneTest\index.php on line 220

    Corrispondente

    $vin=date('d-m-Y',$in[$i]);
    $vout=date('d-m-Y',$out[$i]);

    Come posso risolvere?

  28. #28
    User Newbie
    Data Registrazione
    Jul 2014
    Località
    Roma
    Messaggi
    1
    Stesso errore... non riesco a risolvere...
    Anzi... dopo aver modificato il campo della tabella sql da "date" a int l'errore è questo:
    Notice: Undefined offset: 1420326000 in C:\xampp\htdocs\ZZ - Calendario\index.php on line 299

+ Rispondi alla Discussione

Tag per Questa Discussione

^ Permessi di Scrittura

  • Tu non puoi inviare nuove discussioni
  • Tu non puoi inviare risposte
  • Tu non puoi inviare allegati
  • Tu non puoi modificare i tuoi messaggi
  •  
  • Il codice BB è Attivato
  • Le faccine sono Attivato
  • Il codice [IMG] è Attivato
  • Il codice [VIDEO] è Attivato
  • Il codice HTML è Disattivato
  • Trackbacks Attivato
  • Pingback Attivato
  • Refback Attivato

SEO by vBSEO 3.6.0 PL2 ©2011, Crawlability, Inc.