Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
98.15% covered (success)
98.15%
53 / 54
75.00% covered (warning)
75.00%
3 / 4
CRAP
0.00% covered (danger)
0.00%
0 / 1
RequestReport
98.15% covered (success)
98.15%
53 / 54
75.00% covered (warning)
75.00%
3 / 4
13
0.00% covered (danger)
0.00%
0 / 1
 readResponse
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
1 / 1
3
 writeReport
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
1 / 1
1
 writeHeader
100.00% covered (success)
100.00%
9 / 9
100.00% covered (success)
100.00%
1 / 1
1
 writeReportData
96.55% covered (success)
96.55%
28 / 29
0.00% covered (danger)
0.00%
0 / 1
8
1<?php
2
3/**
4 * @package zmsstatistic
5 * @copyright BerlinOnline Stadtportal GmbH & Co. KG
6 **/
7
8namespace BO\Zmsstatistic\Download;
9
10use BO\Zmsentities\Exchange as ReportEntity;
11use BO\Zmsstatistic\Helper\Download;
12use BO\Zmsstatistic\Helper\ReportHelper;
13use PhpOffice\PhpSpreadsheet\Spreadsheet;
14use Psr\Http\Message\RequestInterface;
15use Psr\Http\Message\ResponseInterface;
16use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
17
18class RequestReport extends Base
19{
20    public $firstDayDate = null;
21
22    public $lastDayDate = null;
23
24    protected $dateFormatter = [
25        'day' => 'Y-m-d',
26        'month' => 'Y-m'
27    ];
28
29    /**
30     * @SuppressWarnings(Param)
31     * @return ResponseInterface
32     */
33    public function readResponse(
34        RequestInterface $request,
35        ResponseInterface $response,
36        array $args
37    ) {
38        $title = 'requeststatistic_' . $args['period'];
39        $download = (new Download($request))->setSpreadSheet($title);
40
41        $this->writeInfoHeader($args, $download->getSpreadSheet());
42        foreach ($args['reports'] as $report) {
43            if ('month' == $report->period) {
44                $this->writeReport($report, $download->getSpreadSheet(), 'yyyy', 'MMMM');
45            } else {
46                $this->writeReport($report, $download->getSpreadSheet());
47            }
48        }
49
50        return $download->writeDownload($response);
51    }
52
53    public function writeReport(
54        ReportEntity $report,
55        Spreadsheet $spreadsheet,
56        $datePatternCol1 = 'MMMM',
57        $datePatternCol2 = 'dd (ccc)'
58    ) {
59        $sheet = $spreadsheet->getActiveSheet();
60
61        $firstDay = $report->firstDay->year . '-' . $report->firstDay->month . '-' . $report->firstDay->day;
62        $lastDay = $report->lastDay->year . '-' . $report->lastDay->month . '-' . $report->lastDay->day;
63        $this->firstDayDate = $this->setDateTime($firstDay);
64        $this->lastDayDate = $this->setDateTime($lastDay);
65
66        $this->writeHeader($report, $sheet, $datePatternCol1, $datePatternCol2);
67        $this->writeReportData($report, $sheet, $datePatternCol1, $datePatternCol2);
68
69        return $spreadsheet;
70    }
71
72    public function writeHeader(ReportEntity $report, $sheet, $datePatternCol1, $datePatternCol2)
73    {
74        $reportHeader = [];
75        $reportHeader[] = 'Dienstleistung';
76        $reportHeader[] = 'Ø Bearbeitungsdauer';
77        $reportHeader[] = $this->getFormatedDates($this->firstDayDate, $datePatternCol1);
78        $dateTime = clone $this->firstDayDate;
79        do {
80            $reportHeader[] = $this->getFormatedDates($dateTime, $datePatternCol2);
81            $dateTime->modify('+1 ' . $report->period);
82        } while ($dateTime <= $this->lastDayDate);
83        $sheet->fromArray($reportHeader, null, 'A' . ($sheet->getHighestRow() + 2));
84    }
85
86    /**
87     * @SuppressWarnings(Unused)
88     */
89    public function writeReportData(ReportEntity $report, $sheet, $datePatternCol1, $datePatternCol2)
90    {
91        $reportData = [];
92        $rowIndex = $sheet->getHighestRow() + 1;
93        $firstDataRow = $rowIndex;
94
95        foreach ($report->data as $name => $entry) {
96            if ($name !== 'sum' && $name !== 'average_processingtime') {
97                $rowData = [];
98                $rowData[] = $name;
99                $rowData[] = isset($report->data['average_processingtime'][$name])
100                    && is_numeric($report->data['average_processingtime'][$name])
101                    ? ReportHelper::formatTimeValue($report->data['average_processingtime'][$name])
102                    : "0";
103                $rowData[] = $report->data['sum'][$name];
104
105                $dateTime = clone $this->firstDayDate;
106                do {
107                    $dateString = $dateTime->format($this->dateFormatter[$report->period]);
108                    $rowData[] = isset($entry[$dateString]) ? (int)$entry[$dateString]['requestscount'] : '0';
109
110
111                    $dateTime->modify('+1 ' . $report->period);
112                } while ($dateTime <= $this->lastDayDate);
113
114                $reportData[$name] = $rowData;
115            }
116        }
117
118        $sheet->fromArray($reportData, null, 'A' . $rowIndex);
119        $lastColumn = $sheet->getHighestColumn();
120        $lastRow = $sheet->getHighestRow();
121        $sumRowIndex = $lastRow + 2;
122        $sumRow = ["Summe", "", ""];
123        $sumRow[2] = "=SUM(C{$firstDataRow}:C{$lastRow})";
124        $lastColumnIndex = Coordinate::columnIndexFromString($lastColumn);
125
126        for ($colIndex = 4; $colIndex <= $lastColumnIndex; $colIndex++) {
127            $colLetter = Coordinate::stringFromColumnIndex($colIndex);
128            $sumRow[] = "=SUM({$colLetter}{$firstDataRow}:{$colLetter}{$lastRow})";
129        }
130
131        $sheet->fromArray($sumRow, null, 'A' . $sumRowIndex);
132    }
133}