'01', 'Febbraio' => '02', 'Marzo' => '03','Aprile' => '04','Maggio' => '05','Giugno' => '06','Luglio' => '07','Agosto' => '08','Settembre' => '09','Ottobre' => '10','Novembre' => '11','Dicembre' => '12'); $month = $months[$month]; $title = $_SESSION['period']['month']; //numero di giorni nel mese $maxday = cal_days_in_month(CAL_GREGORIAN, $month, $year)+1; $mindate = $year.'-'.$month.'-'.'01'; $maxdate = $year.'-'.$month.'-'.$maxday; $where = ' (in_interventi_tecnici.orario_inizio) <= '.prepare($maxdate).' AND (in_interventi_tecnici.orario_inizio) >= '.prepare($mindate).' AND '; } if (isset( $_SESSION['period']['week'] )){ $period = explode(" ", $_SESSION['period']['week']); $day = $period[0]; if (count($period) == 5){ $maxmonth = $period[3]; $maxday_ = $period[2]; $month = $period[3]; $year = $period[4]; } if (count($period) == 6){ $maxmonth = $period[1]; $maxday_ = $period[3]; $month = $period[4]; $year = $period[5]; } $months = array( 'gen' => '01', 'feb' => '02', 'mar' => '03','apr' => '04','mag' => '05','giu' => '06','lug' => '07','ago' => '08','set' => '09','ott' => '10','nov' => '11','dic' => '12'); $month = $months[$month]; $maxmonth = $months[$maxmonth]; $title = $_SESSION['period']['week']; //numero di giorni nel mese $maxday = cal_days_in_month(CAL_GREGORIAN, $month, $year)+1; $mindate = $year.'-'.$month.'-'.$day; $maxdate = $year.'-'.$maxmonth.'-'.$maxday_; //aggiungo un giorno $maxdate = date('Y-m-d',date(strtotime("+1 day", strtotime($maxdate)))); $where = ' (in_interventi_tecnici.orario_inizio) <= '.prepare($maxdate).' AND (in_interventi_tecnici.orario_inizio) >= '.prepare($mindate).' AND '; } $report_name = sanitizeFilename('dashboard_'.$year.'_'.$month.'.pdf'); //$date_start = $_SESSION['period_start']; //$date_end = $_SESSION['period_end']; $stati = (array) $_SESSION['dashboard']['idstatiintervento']; $tipi = (array) $_SESSION['dashboard']['idtipiintervento']; $tecnici = (array) $_SESSION['dashboard']['idtecnici']; //in_interventi_tecnici.idintervento, colore, in_interventi_tecnici.id, idtecnico, orario_inizio, orario_fine,(SELECT ragione_sociale FROM an_anagrafiche WHERE idanagrafica=idtecnico) AS nome_tecnico, (SELECT colore FROM an_anagrafiche WHERE idanagrafica=idtecnico) AS colore_tecnico, $query = 'SELECT DAY(in_interventi_tecnici.orario_inizio) AS giorno, orario_inizio AS data, GROUP_CONCAT((SELECT ragione_sociale FROM an_anagrafiche WHERE idanagrafica=in_interventi.idanagrafica) SEPARATOR \'
\') AS cliente FROM in_interventi_tecnici INNER JOIN (in_interventi LEFT OUTER JOIN in_statiintervento ON in_interventi.idstatointervento=in_statiintervento.idstatointervento) ON in_interventi_tecnici.idintervento=in_interventi.id WHERE '.$where.' idtecnico IN('.implode(',', $tecnici).') AND in_interventi.idstatointervento IN('.implode(',', $stati).') AND in_interventi_tecnici.idtipointervento IN('.implode(',', $tipi).') '.Modules::getAdditionalsQuery('Interventi')." GROUP BY giorno ORDER BY CAST(giorno AS UNSIGNED)"; //echo $query; $sessioni = $dbo->fetchArray($query); //echo $query; $rs = array(); for ($i=0; $i<33;$i++){ $rs[$sessioni[$i]['giorno']]['cliente'] = $sessioni[$i]['cliente']; $rs[$sessioni[$i]['giorno']]['data'] = $sessioni[$i]['data']; } function showMonth($month, $year, &$rs, &$height){ $date = mktime(12, 0, 0, $month, 1, $year); $daysInMonth = date("t", $date); // calculate the position of the first day in the calendar (sunday = 1st column, etc) $offset = (date("w", $date)-1)%7; if ($offset<0){ $offset = 7+$offset; } //echo $date."
"; //echo date("w", $date)."
"; //echo $offset; $rows = 1; //echo "

Displaying calendar for " . date("F Y", $date) . "

\n"; $header = array(); $row = array(); //$table .= "\n"; //echo "\t"; // $table .= "\t"; //$header[$rows] = "\n\t"; //$row[$rows] = "\n\t"; //giorni prima for($i = 1; $i <= $offset; $i++){ $current_month = $month; if($current_month==1){ $current_month = 12; $current_year = $year-1; }else{ $current_month = $month-1; $current_year = $year; } $lastdateofmonth=date('t',$current_month); //$lastdate = $lastdateofmonth."/".$current_month."/".$current_year; $day = (($lastdateofmonth-$offset)+($i)); $weekday = date('l', strtotime($current_year.'-'.$current_month.'-'.(sprintf("%02d", $day)))); $weekdays = array( 'Monday' => 'Lunedi\'', 'Tuesday' => 'Martedi\'', 'Wednesday' => 'Mercoledi\'','Thursday' => 'Giovedi\'','Friday' => 'Venerdi\'','Saturday' => 'Sabato','Sunday' => 'Domenica'); $weekday = $weekdays[$weekday]; $header[$rows] .= "\n"; $row[$rows] .= "\n"; } //giorni del mese for($day = 1; $day <= $daysInMonth; $day++){ if( ($day + $offset - 1) % 7 == 0 && $day != 1) { // $table .= "\t"; // $header[$rows] .= "\n\t"; //$row[$rows] .= "\n\t"; $rows++; } $weekday = date('l', strtotime($year.'-'.$month.'-'.(sprintf("%02d", $day)))); $weekdays = array( 'Monday' => 'Lunedi\'', 'Tuesday' => 'Martedi\'', 'Wednesday' => 'Mercoledi\'','Thursday' => 'Giovedi\'','Friday' => 'Venerdi\'','Saturday' => 'Sabato','Sunday' => 'Domenica'); $weekday = $weekdays[$weekday]; $header[$rows] .= "\n"; if (empty($rs[$day]['cliente'])){ $rs[$day]['cliente'] = ' '; } $row[$rows] .= "\n"; } //$i = 1; //giorni dopo //while( ($day + $offset) <= $rows * 7){ for($i = 1; ($day + $offset) <= ($rows * 7); $i++){ $current_month = $month; if($current_month==12){ $current_month = 1; $current_year = $year+1; }else{ $current_month = $month+1; $current_year = $year; } //$lastdateofmonth = date('t',$current_month); //$lastdate = $lastdateofmonth."/".$current_month."/".$current_year; $weekday = date('l', strtotime($current_year.'-'.$current_month.'-'.(sprintf("%02d", $i)))); $weekdays = array( 'Monday' => 'Lunedi\'', 'Tuesday' => 'Martedi\'', 'Wednesday' => 'Mercoledi\'','Thursday' => 'Giovedi\'','Friday' => 'Venerdi\'','Saturday' => 'Sabato','Sunday' => 'Domenica'); $weekday = $weekdays[$weekday]; $header[$rows] .= "\n"; //$row[$rows] .= "\n"; $row[$rows] .= "\n"; $day++; } //$header[$rows] .= ""; //$row[$rows] .= ""; //print_r($header); //echo "
"; //print_r($row); echo '
SuMTuWThFSa
LunMarMerGioVenSabDom
".tr($weekday.' '.(sprintf("%02d", $day)).'/'.(sprintf("%02d", $current_month)), [], ['upper' => true])."
Lun ".$day."Mar ".($day+1)."Mer ".($day+2)."Gio ".($day+3)."Ven ".($day+4)."Sab ".($day+5)."Dom ".($day+6)."
" . tr($weekday.' '.(sprintf("%02d", $day)).'/'.$month, [], ['upper' => true]) ."". "".$rs[$day]['cliente']." ".tr($weekday.' '.(sprintf("%02d", $i)).'/'.(sprintf("%02d", $current_month)), [], ['upper' => true])." ".($offset+$day)."
".($rows * 7)."
\n'; //creo righe for ($i=1; $i<=count($row);$i++){ echo "\n"; echo $header[$i]; echo "\n"; echo "\n"; echo $row[$i]; echo "\n"; } echo '
'; //$table .= "\n"; //echo $table; } // Intestazione tabella per righe echo "

".tr('Calendario _PERIOD_', [ '_PERIOD_' => $title ], ['upper' => true])."

"; showMonth($month,$year,$rs, $height);