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_userfield extends plugin_base{
28
 
29
    public function init() {
30
        $this->fullname = get_string('userfield', 'block_configurable_reports');
31
        $this->type = 'undefined';
32
        $this->form = true;
33
        $this->reporttypes = array('users');
34
    }
35
 
36
    public function summary($data) {
37
        return format_string($data->columname);
38
    }
39
 
40
    public function colformat($data) {
41
        $align = (isset($data->align)) ? $data->align : '';
42
        $size = (isset($data->size)) ? $data->size : '';
43
        $wrap = (isset($data->wrap)) ? $data->wrap : '';
44
        return array($align, $size, $wrap);
45
    }
46
 
47
    // Data -> Plugin configuration data.
48
    // Row -> Complet user row c->id, c->fullname, etc...
49
    public function execute($data, $row, $user, $courseid, $starttime = 0, $endtime = 0) {
50
        global $DB, $CFG;
51
 
52
        if (strpos($data->column, 'profile_') === 0) {
53
            $sql = "SELECT d.*, f.shortname, f.datatype
54
                      FROM {user_info_data} d ,{user_info_field} f
55
                     WHERE f.id = d.fieldid AND d.userid = ?";
56
            if ($profiledata = $DB->get_records_sql($sql, array($row->id))) {
57
                foreach ($profiledata as $p) {
58
                    if ($p->datatype == 'checkbox') {
59
                        $p->data = ($p->data) ? get_string('yes') : get_string('no');
60
                    }
61
                    if ($p->datatype == 'datetime') {
62
                        $p->data = userdate($p->data);
63
                    }
64
                    $row->{'profile_'.$p->shortname} = $p->data;
65
                }
66
            }
67
        }
68
 
69
        $row->fullname = fullname($row);
70
 
71
        if (isset($row->{$data->column})) {
72
            switch($data->column){
73
                case 'firstaccess':
74
                case 'lastaccess':
75
                case 'currentlogin':
76
                case 'timemodified':
77
                case 'lastlogin':
78
                    $row->{$data->column} = ($row->{$data->column}) ? userdate($row->{$data->column}) : '--';
79
                    break;
80
                case 'confirmed':
81
                case 'policyagreed':
82
                case 'maildigest':
83
                case 'ajax':
84
                case 'autosubscribe':
85
                case 'trackforums':
86
                case 'screenreader':
87
                case 'emailstop':
88
                    $row->{$data->column} = ($row->{$data->column}) ? get_string('yes') : get_string('no');
89
                    break;
90
            }
91
        }
92
        return (isset($row->{$data->column})) ? $row->{$data->column} : '';
93
    }
94
}