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