Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 45
0.00% covered (danger)
0.00%
0 / 3
CRAP
0.00% covered (danger)
0.00%
0 / 1
tao_helpers_report_Rendering
0.00% covered (danger)
0.00%
0 / 45
0.00% covered (danger)
0.00%
0 / 3
306
0.00% covered (danger)
0.00%
0 / 1
 render
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 1
72
 renderReport
0.00% covered (danger)
0.00%
0 / 23
0.00% covered (danger)
0.00%
0 / 1
72
 renderToCommandline
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2013 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
19 *
20 */
21
22/**
23 * This helper aims at providing utility methods to render
24 * reports into HTML.
25 *
26 * @author Jérôme Bogaerts <jerome@taotesting.com>
27 *
28 */
29class tao_helpers_report_Rendering
30{
31    /**
32     * Render a common_report_Report object into an HTML string output.
33     *
34     * @param common_report_Report $report A report to be rendered
35     * @return string The HTML rendering.
36     */
37    public static function render(common_report_Report $report)
38    {
39
40        $stack = new SplStack();
41        $renderingStack = new SplStack();
42        $traversed = [];
43
44        $stack->push($report);
45        $nesting = 0;
46
47        while ($stack->count() > 0) {
48            $current = $stack->pop();
49
50            if (in_array($current, $traversed, true) === false && $current->hasChildren() === true) {
51                $nesting++;
52                // -- Hierarchical report, 1st pass (descending).
53
54                // Repush report for a 2ndpass.
55                $stack->push($current);
56
57                // Tag as already traversed.
58                $traversed[] = $current;
59
60                // Push the children for a 1st pass.
61                foreach ($current as $child) {
62                    $stack->push($child);
63                }
64            } elseif (in_array($current, $traversed, true) === true && $current->hasChildren() === true) {
65                $nesting--;
66                // -- Hierachical report, 2nd pass (ascending).
67
68                // Get the nested renderings of the current report.
69                $children = [];
70                foreach ($current as $child) {
71                    $children[] = $renderingStack->pop();
72                }
73
74                $renderingStack->push(self::renderReport($current, $children, $nesting));
75            } else {
76                // -- Leaf report, 1st & single pass.
77                $renderingStack->push(self::renderReport($current, [], $nesting, true));
78            }
79        }
80
81        return $renderingStack->pop();
82    }
83
84    /**
85     * Contains the logic to render a report and its children.
86     *
87     * @param common_report_Report $report A report to be rendered.
88     * @param array $childRenderedReports An array of strings containing the separate rendering of $report's child
89     *                                    reports.
90     * @param integer $nesting The current nesting level (root = 0).
91     * @return string The HTML output of $report.
92     */
93    private static function renderReport(
94        common_report_Report $report,
95        array $childRenderedReports = [],
96        $nesting = 0,
97        $leaf = false
98    ) {
99
100        switch ($report->getType()) {
101            case common_report_Report::TYPE_SUCCESS:
102                $typeClass = 'success';
103                break;
104
105            case common_report_Report::TYPE_WARNING:
106                $typeClass = 'warning';
107                break;
108
109            case common_report_Report::TYPE_ERROR:
110                $typeClass = 'error';
111                break;
112
113            default:
114                $typeClass = 'info';
115                break;
116        }
117
118        $openingTag = '<div class="feedback-' . $typeClass . ' feedback-nesting-' . $nesting . ' '
119            . (($leaf === true) ? 'leaf' : 'hierarchical') . ' tao-scope">';
120        $leafIcon = ($leaf === true) ? ' leaf-icon' : ' hierarchical-icon';
121        $icon = '<span class="icon-' . $typeClass . $leafIcon . '"></span>';
122        $message = nl2br(_dh($report->__toString()));
123        $endingTag = '</div>';
124        $okButton = '<p><button id="import-continue" class="btn-info"><span class="icon-right"></span>'
125            . __("Continue") . '</button></p>';
126
127        // Put all the children renderings together.
128        $content = implode('', $childRenderedReports);
129        return $openingTag . $icon . $message . $content . (($nesting != 0) ? '' : $okButton) . $endingTag;
130    }
131
132    /**
133     * Contains the logic to render a report and its children to the command line
134     *
135     * @deprecated
136     * @param common_report_Report $report A report to be rendered.
137     * @param integer $intend the intend of the message.
138     * @return string The command line output of $report.
139     */
140    public static function renderToCommandline(common_report_Report $report, $intend = 0)
141    {
142        return helpers_Report::renderToCommandLine($report, helpers_Report::AUTOSENSE, $intend);
143    }
144}