Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
2
// This file is part of Moodle - http://moodle.org/
3
//
4
// Moodle is free software: you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation, either version 3 of the License, or
7
// (at your option) any later version.
8
//
9
// Moodle 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 Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
 
17
/**
18
 * Configurable Reports
19
 * A Moodle block for creating customizable reports
20
 * @package blocks
21
 * @author: Juan leyva <http://www.twitter.com/jleyvadelgado>
22
 * @date: 2009
23
 */
24
 
25
require_once($CFG->dirroot.'/blocks/configurable_reports/plugin.class.php');
26
 
27
class plugin_average extends plugin_base{
28
 
29
    public function init() {
30
        $this->form = true;
31
        $this->unique = false;
32
        $this->fullname = get_string('average', 'block_configurable_reports');
33
        $this->reporttypes = array('courses', 'users', 'sql', 'timeline', 'categories');
34
    }
35
 
36
    public function summary($data) {
37
        global $DB, $CFG;
38
 
39
        if ($this->report->type != 'sql') {
40
            $components = cr_unserialize($this->report->components);
41
            if (!is_array($components) || empty($components['columns']['elements'])) {
42
                print_error('nocolumns');
43
            }
44
 
45
            $columns = $components['columns']['elements'];
46
            $i = 0;
47
            foreach ($columns as $c) {
48
                if ($i == $data->column) {
49
                    return $c['summary'];
50
                }
51
                $i++;
52
            }
53
        } else {
54
 
55
            require_once($CFG->dirroot.'/blocks/configurable_reports/report.class.php');
56
            require_once($CFG->dirroot.'/blocks/configurable_reports/reports/'.$this->report->type.'/report.class.php');
57
 
58
            $reportclassname = 'report_'.$this->report->type;
59
            $reportclass = new $reportclassname($this->report);
60
 
61
            $components = cr_unserialize($this->report->components);
62
            $config = (isset($components['customsql']['config'])) ? $components['customsql']['config'] : new \stdclass;
63
 
64
            if (isset($config->querysql)) {
65
 
66
                $sql = $config->querysql;
67
                $sql = $reportclass->prepare_sql($sql);
68
                if ($rs = $reportclass->execute_query($sql)) {
69
                    foreach ($rs as $row) {
70
                        $i = 0;
71
                        foreach ($row as $colname => $value) {
72
                            if ($i == $data->column) {
73
                                return str_replace('_', ' ', $colname);
74
                            }
75
                            $i++;
76
                        }
77
                        break;
78
                    }
79
                    $rs->close();
80
                }
81
            }
82
        }
83
 
84
        return '';
85
    }
86
 
87
    public function execute($rows) {
88
        $result = 0;
89
        $els = 0;
90
        foreach ($rows as $r) {
91
            $result += (is_numeric($r)) ? $r : 0;
92
            $els++;
93
        }
94
        if ($els == 0) {
95
            $els = 1;
96
        }
97
        return round($result / $els, 2);
98
    }
99
}