Planner con tabella in PHP

neo996sps

Utente Attivo
31 Mag 2007
247
0
0
Trentino
Ciao a tutti,

continuano le mie peregrinazioni con PHP. Stavolta il problema è piuttosto impegnativo e non so come risolverlo. Devo creare un planner per il noleggio di alcuni mezzi. In pratica deve uscirmi una tabella fatta così:

| | 1 | 2 | 3 | .... |31|
| AA000AA| | | | ... | |
| ... | | | | | |
| ZZ000ZZ| | | | | |

La prima colonna ho le targhe relative ai mezzi, in tutte le altre vorrei colorare la cella nel caso la macchina non sia disponibile. Ho quindi creato due tabelle in MySQL di cui questo è il dump:

Codice:
CREATE TABLE IF NOT EXISTS `flotta` (
  `id` bigint(50) NOT NULL auto_increment,
  `targa` varchar(7) default NULL,
  `telaio` varchar(255) default NULL,
  `modello` varchar(150) default NULL,
  `versione` varchar(255) default NULL,
  `colore` varchar(100) default NULL,
  `lungo_periodo` tinyint(1) default NULL,
  `km` varchar(10) default NULL,
  `carburante` varchar(20) default NULL,
  `kw` varchar(10) default NULL,
  `cv` varchar(10) default NULL,
  `cilindrata` varchar(10) default NULL,
  `data_immatricolazione` varchar(10) default NULL,
  `categoria` varchar(255) NOT NULL,
  PRIMARY KEY  (`id`),
  UNIQUE KEY `telaio` (`telaio`),
  UNIQUE KEY `targa` (`targa`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

CREATE TABLE IF NOT EXISTS `noleggio` (
  `id` bigint(50) NOT NULL auto_increment,
  `contratto` varchar(20) default NULL,
  `data_inizio` date default NULL,
  `data_fine` date default NULL,
  `ragione_sociale` varchar(255) default NULL,
  `mezzo` varchar(255) default NULL,
  `noleggiato` tinyint(1) NOT NULL,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

Mentre questo è il codice per il planner:

Codice:
<table width="100%">
<thead>
<tr>
<th style='text-align:center'></th>
<?php
      $mese = mktime( 0, 0, 0, $m, 1, $y ); 
      $numeroDigiorni = intval(date("t",$mese)); 
      for($i=1; $i<=$numeroDigiorni; $i++)
      {
       print("<th width='2%'>".$i."</th>");
      }
?>
</thead>
<?php
$count1 = 0;
$res1 = mysql_query( "SELECT * FROM flotta ORDER BY targa;");
while ( $riga1 = mysql_fetch_array( $res1 ) ) {
		$dateform = explode( '-', $riga1["data"] );
		$datafin = $dateform[2].'.'.$dateform[1].'.'.$dateform[0];
			  
?> 


<tbody>
<?php
$mese = mktime( 0, 0, 0, $m, 1, $y ); 
$numeroDigiorni = intval(date("t",$mese));  
print("<tr>");
print("<td style='text-align:center'><a href='./nuovo_noleggio.php?targa=".$riga1["targa"]."&modello=".$riga1["modello"]."&versione=".$riga1["versione"]."'>".$riga1["targa"]." ".$riga1["modello"]." ".$riga1["versione"]."</a></td>");

      for($i=1; $i<=$numeroDigiorni; $i++)
      { 
      
       print("<td></td>");
      }  
      print("</tr>");
}
?>
</tbody>
</table>

Come potete vedere sono riuscito a creare dinamicamente la tabella incaricata di fare il planner, però non so come scrivere in PHP: se il mezzo AA000AA è legato ad un noleggio tra la data X e la data Y allora colora la cella in rosso, altrimenti lasciala bianca.

Come potrei fare? Avete qualche input da darmi?
 

tiberi72

Nuovo Utente
29 Apr 2011
16
0
0
dovresti fare un'altra select per noleggio cosi' come hai fatto per flotta, solo che sul campo where indichi il campo di riferimento a flotta.
PHP:
<table width="100%">
<thead>
<tr>
<th style='text-align:center'></th>
<?php
      $mese = mktime( 0, 0, 0, $m, 1, $y ); 
      $numeroDigiorni = intval(date("t",$mese)); 
      for($i=1; $i<=$numeroDigiorni; $i++)
      {
       print("<th width='2%'>".$i."</th>");
      }
?>
</thead>
<?php
$count1 = 0;
$res1 = mysql_query( "SELECT * FROM flotta ORDER BY targa;");
while ( $riga1 = mysql_fetch_array( $res1 ) ) {
		$dateform = explode( '-', $riga1["data"] );
		$datafin = $dateform[2].'.'.$dateform[1].'.'.$dateform[0];
			  
?> 


<tbody>
<?php
print("<tr>");
$mese = mktime( 0, 0, 0, $m, 1, $y ); 
$numeroDigiorni = intval(date("t",$mese));  
$res2 = mysql_query( "SELECT * FROM noleggio where mezzo = ".$riga1["targa"].";");
while ( $riga2 = mysql_fetch_array( $res2 ) ) {
  if ($riga2['noleggiato']==0) {
    $mess="<td style='text-align:center; color=red;'><a href='./nuovo_noleggio.php?targa=".$riga1["targa"]."&modello=".$riga1 ["modello"]."&versione=".$riga1["versione"]."'>".$riga1["targa"]." ".$riga1["modello"]." ".$riga1["versione"]."</a></td>";
  } else {
    $mess="<td style='text-align:center; color=blue;'><a href='./nuovo_noleggio.php?targa=".$riga1["targa"]."&modello=".$riga1   ["modello"]."&versione=".$riga1["versione"]."'>".$riga1["targa"]." ".$riga1["modello"]." ".$riga1["versione"]."</a></td>";
}
 print($mess);

      for($i=1; $i<=$numeroDigiorni; $i++)
      { 
      
       print("<td></td>");
      }  
      print("</tr>");
}
?>
</tbody>
</table>
spero di aver capito bene cosa intendi.
personalmente preferisco usare l'istruzione echo anziche' print, ma penso che sia lo stesso.
Sicuramente ci possono essere degli errori di sintassi in quello che ho scritto, ho fatto tutto "a braccio"
 

neo996sps

Utente Attivo
31 Mag 2007
247
0
0
Trentino
Ciao,

allora ho provato il codice e funziona in parte. Infatti mi segna nella prima cella della tabella che creo il noleggio, ma io vorrei che si colorassero le celle interessate: se io noleggio la macchina 1 dal 5 agosto al 15 agosto vorrei che si colorassero di rosso quelle.

Mi sai dare un'altro aiuto?
 

tiberi72

Nuovo Utente
29 Apr 2011
16
0
0
Allora, e' un po' piu' complicato e bisogna chiarire prima di tutto qualcosa a livello di logica:
1) quante righe di noleggio posso avere per lo stesso mezzo? Se ci sono piu' righe di noleggio, sono sicuro che le date di noleggio non si sovrappongono?
2) una volta stabilite le date, devo riuscire a trasformare la data in giorni e devo sempre pensare che posso avere delle date a cavallo del mese (esempio se noleggio dal 25/07 al 05/08 i giorni da colorare in questo caso sarebbero 1, 2 , 3 , 4, 5, 25, 26, 27, 28,29, 30, 31 e mi sembra che crei qualche confusione)
 

neo996sps

Utente Attivo
31 Mag 2007
247
0
0
Trentino
Ciao,

allora, un mezzo può essere noleggiato ad un unico cliente per il periodo che va da X a Y. Per quanto riguarda il "cavallo" tra due mesi sarebbe risolvibile ampilando la tabella a più mesi e facendola scorrevole.
 

tiberi72

Nuovo Utente
29 Apr 2011
16
0
0
prova cosi':
PHP:
<table width="100%"> 
<thead> 
<tr> 
<th style='text-align:center'></th> 
<?php 
      $mese = mktime( 0, 0, 0, $m, 1, $y );  
      $numeroDigiorni = intval(date("t",$mese));  
      for($i=1; $i<=$numeroDigiorni; $i++) 
      { 
       print("<th width='2%'>".$i."</th>"); 
      } 
?> 
</thead> 
<?php 
$count1 = 0; 
$res1 = mysql_query( "SELECT * FROM flotta ORDER BY targa;"); 
while ( $riga1 = mysql_fetch_array( $res1 ) ) { 
        $dateform = explode( '-', $riga1["data"] ); 
        $datafin = $dateform[2].'.'.$dateform[1].'.'.$dateform[0]; 
               
?>  


<tbody> 
<?php 
print("<tr>"); 
$mese = mktime( 0, 0, 0, $m, 1, $y );  
$numeroDigiorni = intval(date("t",$mese));   
$mess="<td style='text-align:center;'><a href='./nuovo_noleggio.php?targa=".$riga1["targa"]."&modello=".$riga1 ["modello"]."&versione=".$riga1["versione"]."'>".$riga1["targa"]." ".$riga1["modello"]." ".$riga1["versione"]."</a></td>"; 
 print($mess); 

      for($i=1; $i<=$numeroDigiorni; $i++) 
      {  

          $res2 = mysql_query( "SELECT * FROM noleggio where mezzo = ".$riga1["targa"].";"); 
          while ( $riga2 = mysql_fetch_array( $res2 ) ) { 
              if ($riga2['noleggiato']==1) and (date("d",$riga2['data_inizio'])>=$i) and (date("d",$riga2['data_fine'])<=$i){ 
                 $mess="<td style=color=red;'$i</td>"; 
              } else { 
                 $mess="<td style=color=blue;'$i</td>"; 
              } 
       
       print($mess); 
      }   
      print("</tr>"); 
} 
?> 
</tbody> 
</table>
forse manca qualòche conversione del tipo data, non saprei..
 

neo996sps

Utente Attivo
31 Mag 2007
247
0
0
Trentino
mi generava un errore sull'if e allora sono riuscito a risolvere così:

PHP:
<table width="100%">
<thead>
<tr>
<th style='text-align:center'></th>
<?php
      $mese = mktime( 0, 0, 0, $m, 1, $y ); 
      $numeroDigiorni = intval(date("t",$mese)); 
      for($i=1; $i<=$numeroDigiorni; $i++)
      {
       print("<th width='2%'>".$i."</th>");
      }
?>
</thead>
<?php
$count1 = 0;
$res1 = mysql_query( "SELECT * FROM flotta;");
while ( $riga1 = mysql_fetch_array( $res1 ) ) {
        $dateform = explode( '-', $riga1["data"] );
        $datafin = $dateform[2].'.'.$dateform[1].'.'.$dateform[0];
              
?> 


<tbody>
<?php
print("<tr>");
print("<td>".$riga1["targa"]." - ".$riga1["modello"]." - ".$riga1["versione"]."</td>");
$mese = mktime( 0, 0, 0, $m, 1, $y ); 
$numeroDigiorni = intval(date("t",$mese));  
$res2 = mysql_query( "SELECT * FROM noleggio WHERE mezzo = '".$riga1["targa"]."';");
while ( $riga2 = mysql_fetch_array( $res2 ) ) {
if (($riga2['noleggiato']==1) AND (date("d",$riga2['data_inizio'])>=$i) AND (date("d",$riga2['data_fine'])<=$i)){ 
                 $mess="<td style=color=red;'$i</td>"; 
              } else { 
                 $mess="<td style=color=blue;'$i</td>"; 
              } 
       
       print($mess);  

      for($i=1; $i<=$numeroDigiorni; $i++)
      { 
      
       print("<td></td>");
      }  
      print("</tr>");
}   }
?>
</tbody>
</table>

ma ancora non funziona. A sto punto controllerò meglio domani mattina perchè sono cotto. Ragazzi, intanto grazie dell'aiuto. Se avessi ancora problemi posto e vi faccio sapere
 
Discussioni simili
Autore Titolo Forum Risposte Data
N Alternativa valida e gratuita allo keyword planner di Google Adwords ? SEO e Posizionamento 0
E Problema accesso a file con app sviluppata con MIT APP INVENTOR 2 Sviluppo app per Android 0
M Unire 2 funzioni per l'invio di un form e con l'apertura di un div Javascript 0
D Carousel bootstrap con video HTML e CSS 2
D Come estendere la tariffa per Wordpress con Visa? Hosting 1
T [VENDO] Guest Post su siti di Proprietà con IP diversi Offerte e Richieste di scambio links 0
A Somma di orari con centesimi PHP 1
T Query su due tabelle con totali Database 4
F Scrivere dei dati in word con php PHP 0
otto9due Più chiavi in array con array_key_exists() PHP 0
M Conteggio con group by PHP 3
M Problema con Try Catch PHP 0
K Aiuto con file audio in html HTML e CSS 1
M Upload immagine con javascript problemi con FormData() Javascript 1
M Visulizzare immagine con php PHP 8
G [PHP] Creare script di prenotazione con controllo disponibilità. PHP 7
G leggere file txt e stampare con php il contenuto a video PHP 7
M Riportare in tabella HTML dati estratti con query SQL MySQL 0
Z PHP.INI - STMP per invio email con PHP Server Dedicati e VPS 0
Sergio Unia Problema con gli eventi del mouse su una data table: Javascript 2
G Invio form con PHP PHP 3
M Barra di navigazione con google HTML e CSS 1
T PROBLEMA CON SESSIONI PHP 3
A Problemi con move_uploaded_file PHP 7
G Menù a tendina di ricerca con query PHP 1
T fatture con voci fattura in php PHP 0
A Tabella con bottoni per aggiornamento record PHP 6
M Come selezionare e deselezionare radiobutton con jquery jQuery 1
MarcoGrazia Calcolo fra due date con esclusione delle feste PHP 7
T ALTRO PROBLEMA CON ARRAY PHP PHP 1
T PROBLEMA CON ARRAY PHP 8
M Inviare un file su un server remoto con JavaScript Javascript 0
L problema con query select PHP 2
M Come validare textarea con jquery jQuery 0
M Problemi con la stampa dei valori in php PHP 1
A Regex per isolare link interni con rel noopener PHP 0
L Problemi con il login PHP 2
F Creare elementi html con javascript Javascript 4
R Problema query con ricerca id numerico PHP 2
R [C#] Quali dipendenze occorrono su progetto "Setup" con Access Database? .NET Framework 0
F Problema con risposta PHP 0
A Sottoquery con group by per mese MySQL 0
R Aggiornare record mysql con Ajax, jQuery e php Ajax 2
A Quale NVR con ingressi bnc ? IP Cam e Videosorveglianza 1
S problema con recupero dati tabella mysql PHP 2
Z Problema con il mio tp-l i nk Reti LAN e Wireless 1
T Film interattivo con linguaggi web Programmazione 7
A pulsante di update campo mysql con javascript Javascript 2
R Tutto su utf-8 ma ancora problemi con i caratteri speciali in mysql MySQL 1
Barierta Testo a comparsa con passaggio del mouse Javascript 17

Discussioni simili