Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
96.63% covered (success)
96.63%
86 / 89
66.67% covered (warning)
66.67%
6 / 9
CRAP
0.00% covered (danger)
0.00%
0 / 1
ClientReport
96.63% covered (success)
96.63%
86 / 89
66.67% covered (warning)
66.67%
6 / 9
41
0.00% covered (danger)
0.00%
0 / 1
 readResponse
100.00% covered (success)
100.00%
10 / 10
100.00% covered (success)
100.00%
1 / 1
4
 writeReport
100.00% covered (success)
100.00%
5 / 5
100.00% covered (success)
100.00%
1 / 1
1
 writeReportHeader
100.00% covered (success)
100.00%
18 / 18
100.00% covered (success)
100.00%
1 / 1
8
 writeTotalsRow
95.45% covered (success)
95.45%
21 / 22
0.00% covered (danger)
0.00%
0 / 1
8
 writeReportData
100.00% covered (success)
100.00%
22 / 22
100.00% covered (success)
100.00%
1 / 1
8
 calculateNoAppointment
66.67% covered (warning)
66.67%
2 / 3
0.00% covered (danger)
0.00%
0 / 1
3.33
 calculateMissedNoAppointment
66.67% covered (warning)
66.67%
2 / 3
0.00% covered (danger)
0.00%
0 / 1
3.33
 calculateNoAppointmentForRow
100.00% covered (success)
100.00%
3 / 3
100.00% covered (success)
100.00%
1 / 1
3
 calculateMissedNoAppointmentForRow
100.00% covered (success)
100.00%
3 / 3
100.00% covered (success)
100.00%
1 / 1
3
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 PhpOffice\PhpSpreadsheet\Spreadsheet;
13use Psr\Http\Message\RequestInterface;
14use Psr\Http\Message\ResponseInterface;
15
16class ClientReport extends Base
17{
18    /**
19     * @SuppressWarnings(Param)
20     * @return ResponseInterface
21     */
22    public function readResponse(
23        RequestInterface $request,
24        ResponseInterface $response,
25        array $args
26    ) {
27        $title = 'clientstatistic_' . $args['period'];
28        $download = (new Download($request))->setSpreadSheet($title);
29        $spreadsheet = $download->getSpreadSheet();
30        $spreadsheet = $this->writeInfoHeader($args, $spreadsheet);
31        if ($args['reports']) {
32            foreach ($args['reports'] as $report) {
33                if ('month' == $report->period) {
34                    $spreadsheet = $this->writeReport($report, $download->getSpreadSheet(), 'yyyy', 'MMMM', 'yyyy');
35                } else {
36                    $spreadsheet = $this->writeReport($report, $download->getSpreadSheet());
37                }
38            }
39        }
40        return $download->writeDownload($response);
41    }
42
43    public function writeReport(
44        ReportEntity $report,
45        Spreadsheet $spreadsheet,
46        $datePatternTotals = 'MMMM',
47        $datePatternCol1 = 'ccc',
48        $datePatternCol2 = 'dd.MM.yy'
49    ) {
50        $sheet = $spreadsheet->getActiveSheet();
51        $this->writeReportHeader($report, $sheet);
52        $this->writeTotalsRow($report, $sheet, $datePatternTotals);
53        $this->writeReportData($report, $sheet, $datePatternCol1, $datePatternCol2);
54
55        return $spreadsheet;
56    }
57
58    public function writeReportHeader(ReportEntity $report, $sheet)
59    {
60        $reportHeader = [];
61        if ('totals' == end($report->data)['date'] || 'month' == $report->period) {
62            $reportHeader[] = null;
63        }
64        $columnIndex = 0;
65        foreach (array_keys($report->data[0]) as $headline) {
66            $columnIndex++;
67            if ($columnIndex == 3 || $columnIndex == 4) {
68                continue;
69            }
70
71            if (!in_array($headline, static::$ignoreColumns)) {
72                if (isset(static::$headlines[$headline])) {
73                    $reportHeader[] = static::$headlines[$headline];
74                }
75            }
76        }
77
78        // Placeholders for the new columns
79        $end = array_splice($reportHeader, -1);  // get the last element
80        $reportHeader[] = static::$headlines['noappointment'];
81        $reportHeader[] = static::$headlines['missednoappointment'];
82        $reportHeader[] = static::$headlines['ticketprinter'];
83        $reportHeader[] = static::$headlines['ticketprintermissed'];
84
85        $reportHeader = array_merge($reportHeader, $end);  // append them back after adding new headers
86
87
88        $sheet->fromArray($reportHeader, null, 'A' . ($sheet->getHighestRow() + 2));
89    }
90
91    public function writeTotalsRow(ReportEntity $report, $sheet, $datePatternTotals)
92    {
93        if ('totals' == end($report->data)['date']) {
94            $totals = array_pop($report->data);
95            $dateString = $report->firstDay->year . '-' . $report->firstDay->month . '-' . $report->firstDay->day;
96            $dateCol1 = ('MMMM' == $datePatternTotals) ?
97                $this->getFormatedDates($this->setDateTime($dateString), $datePatternTotals) :
98                null;
99            $dateCol2 = $this->setDateTime($dateString)->format('Y');
100            $reportTotal = [$dateCol1, $dateCol2];
101
102            $columnIndex = 0;
103            foreach ($totals as $key => $item) {
104                $columnIndex++;
105                if ($columnIndex == 3 || $columnIndex == 4) {
106                    continue;
107                }
108
109                if (! in_array($key, static::$ignoreColumns) && 'date' != $key) {
110                    $reportTotal[] = (string)($item);
111                }
112            }
113
114            // Calculations for the new columns
115            $end = array_splice($reportTotal, -1);
116
117            $reportTotal[] = $this->calculateNoAppointment($totals);
118            $reportTotal[] = $this->calculateMissedNoAppointment($totals);
119            $reportTotal[] = (string)($totals['ticketprinter'] ?? 0);
120            $reportTotal[] = (string)($totals['ticketprintermissed'] ?? 0);
121
122            $reportTotal = array_merge($reportTotal, $end);
123
124            $sheet->fromArray($reportTotal, null, 'A' . ($sheet->getHighestRow() + 1));
125        }
126    }
127
128    public function writeReportData(ReportEntity $report, $sheet, $datePatternCol1, $datePatternCol2)
129    {
130        $reportData = [];
131
132        foreach ($report->data as $row => $entry) {
133            $processedRow = [];
134            $columnIndex = 0;
135
136            foreach ($entry as $key => $item) {
137                $columnIndex++;
138                if ($columnIndex == 3 || $columnIndex == 4) {
139                    continue;
140                }
141
142                if (!in_array($key, static::$ignoreColumns)) {
143                    if ('date' == $key) {
144                        $dateCol1 = $this->getFormatedDates($this->setDateTime($item), $datePatternCol1);
145                        $item = $this->getFormatedDates($this->setDateTime($item), $datePatternCol2);
146                        $processedRow[] = $dateCol1;
147                    }
148                    $processedRow[] = (is_numeric($item)) ? (string)($item) : $item;
149                }
150            }
151
152            // Calculations for the new columns
153            $end = array_splice($processedRow, -1);
154
155            $processedRow[] = $this->calculateNoAppointmentForRow($entry);
156            $processedRow[] = $this->calculateMissedNoAppointmentForRow($entry);
157            $processedRow[] = (string)($entry['ticketprinter'] ?? 0);
158            $processedRow[] = (string)($entry['ticketprintermissed'] ?? 0);
159
160            $processedRow = array_merge($processedRow, $end);
161
162            $reportData[$row] = $processedRow;
163        }
164
165        $sheet->fromArray($reportData, null, 'A' . ($sheet->getHighestRow() + 1));
166    }
167
168    private function calculateNoAppointment($totals)
169    {
170        if (isset($totals['clientscount']) && isset($totals['withappointment'])) {
171            return (string) ($totals['clientscount'] - $totals['withappointment']);
172        }
173        return 'N/A';
174    }
175
176    private function calculateMissedNoAppointment($totals)
177    {
178        if (isset($totals['missed']) && isset($totals['missedwithappointment'])) {
179            return (string) ($totals['missed'] - $totals['missedwithappointment']);
180        }
181        return 'N/A';
182    }
183
184    private function calculateNoAppointmentForRow($entry)
185    {
186        if (isset($entry['clientscount']) && isset($entry['withappointment'])) {
187            return (string) ($entry['clientscount'] - $entry['withappointment']);
188        }
189        return 'N/A';
190    }
191
192    private function calculateMissedNoAppointmentForRow($entry)
193    {
194        if (isset($entry['missed']) && isset($entry['missedwithappointment'])) {
195            return (string) ($entry['missed'] - $entry['missedwithappointment']);
196        }
197        return 'N/A';
198    }
199}