'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 = ['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 = [];
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 "
Su | M | Tu | W | Th | F | Sa |
---|---|---|---|---|---|---|
Lun | Mar | Mer | Gio | Ven | Sab | Dom |
'.tr($weekday.' '.(sprintf('%02d', $day)).'/'.(sprintf('%02d', $current_month)), [], ['upper' => true])." | \n"; $row[$rows] .= "\n"; } //giorni del mese for ($day = 1; $day <= $daysInMonth; ++$day) { if (($day + $offset - 1) % 7 == 0 && $day != 1) { // $table .= "\t | |||||
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])." | \n"; if (empty($rs[$day]['cliente'])) { $rs[$day]['cliente'] = ' '; } $row[$rows] .= "".''.$rs[$day]['cliente']." | \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 = ['Monday' => 'Lunedi\'', 'Tuesday' => 'Martedi\'', 'Wednesday' => 'Mercoledi\'', 'Thursday' => 'Giovedi\'', 'Friday' => 'Venerdi\'', 'Saturday' => 'Sabato', 'Sunday' => 'Domenica']; $weekday = $weekdays[$weekday]; $header[$rows] .= ''.tr($weekday.' '.(sprintf('%02d', $i)).'/'.(sprintf('%02d', $current_month)), [], ['upper' => true])." | \n"; //$row[$rows] .= " ".($offset+$day)." ".($rows * 7)." | \n";
$row[$rows] .= "\n"; ++$day; } //$header[$rows] .= " |