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_ccoursefield extends plugin_base{
28
    public function init() {
29
        $this->fullname = get_string('ccoursefield', 'block_configurable_reports');
30
        $this->reporttypes = array('courses');
31
        $this->form = true;
32
    }
33
 
34
    public function summary($data) {
35
        return get_string($data->field).' '.$data->operator.' '.$data->value;
36
 
37
    }
38
 
39
    // Data -> Plugin configuration data.
40
    public function execute($data, $user, $courseid) {
41
        global $DB;
42
 
43
        $data->value = $data->value;
44
        // TODO - Use $DB->sql_like().
45
        $ilike = " LIKE ";
46
 
47
        switch ($data->operator) {
48
            case 'LIKE % %':
49
                $sql = "$data->field $ilike ?";
50
                $params = array("%$data->value%");
51
                break;
52
            default:
53
                $sql = "$data->field $data->operator ?";
54
                $params = array($data->value);
55
        }
56
 
57
        $courses = $DB->get_records_select('course', $sql, $params);
58
 
59
        if ($courses) {
60
            return array_keys($courses);
61
        }
62
 
63
        return array();
64
    }
65
}