moodle/user/portfoliologs.php

161 lines
5.7 KiB
PHP

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* This file is part of the User section Moodle
*
* @copyright 1999 Martin Dougiamas http://dougiamas.com
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @package core_user
*/
require_once(__DIR__ . '/../config.php');
if (empty($CFG->enableportfolios)) {
throw new \moodle_exception('disabled', 'portfolio');
}
require_once($CFG->libdir . '/portfoliolib.php');
require_once($CFG->libdir . '/portfolio/exporter.php');
$courseid = optional_param('courseid', SITEID, PARAM_INT);
$page = optional_param('page', 0, PARAM_INT);
$perpage = optional_param('perpage', 10, PARAM_INT);
if (! $course = $DB->get_record("course", array("id" => $courseid))) {
throw new \moodle_exception('invalidcourseid');
}
require_login($course, false);
$user = $USER;
$fullname = fullname($user);
$strportfolios = get_string('portfolios', 'portfolio');
$url = new moodle_url('/user/portfoliologs.php', array('courseid' => $courseid));
navigation_node::override_active_url(new moodle_url('/user/portfoliologs.php', array('courseid' => $courseid)));
if ($page !== 0) {
$url->param('page', $page);
}
if ($perpage !== 0) {
$url->param('perpage', $perpage);
}
$PAGE->set_url($url);
$PAGE->set_title(get_string('logs', 'portfolio'));
$PAGE->set_heading($fullname);
$PAGE->set_context(context_user::instance($user->id));
$PAGE->set_pagelayout('report');
echo $OUTPUT->header();
$showroles = 1;
$somethingprinted = false;
echo $OUTPUT->box_start();
$queued = $DB->get_records('portfolio_tempdata', array('userid' => $USER->id), 'expirytime DESC', 'id, expirytime');
if (count($queued) > 0) {
$table = new html_table();
$table->head = array(
get_string('displayarea', 'portfolio'),
get_string('plugin', 'portfolio'),
get_string('displayinfo', 'portfolio'),
get_string('displayexpiry', 'portfolio'),
'',
);
$table->data = array();
$now = time();
foreach ($queued as $q) {
$e = portfolio_exporter::rewaken_object($q->id);
$e->verify_rewaken(true);
$queued = $e->get('queued');
$baseurl = new moodle_url('/portfolio/add.php', array('id' => $q->id, 'logreturn' => 1, 'sesskey' => sesskey()));
$iconstr = $OUTPUT->action_icon(new moodle_url($baseurl, array('cancel' => 1)), new pix_icon('t/stop', get_string('cancel')));
if (!$e->get('queued') && $e->get('expirytime') > $now) {
$iconstr .= $OUTPUT->action_icon($baseurl, new pix_icon('t/go', get_string('continue')));
}
$table->data[] = array(
$e->get('caller')->display_name(),
(($e->get('instance')) ? $e->get('instance')->get('name') : get_string('noinstanceyet', 'portfolio')),
$e->get('caller')->heading_summary(),
userdate($q->expirytime),
$iconstr,
);
unset($e); // This could potentially be quite big, so free it.
}
echo $OUTPUT->heading(get_string('queuesummary', 'portfolio'));
echo html_writer::table($table);
$somethingprinted = true;
}
// Paging - get total count separately.
$logcount = $DB->count_records('portfolio_log', array('userid' => $USER->id));
if ($logcount > 0) {
$table = new html_table();
$table->head = array(
get_string('plugin', 'portfolio'),
get_string('displayarea', 'portfolio'),
get_string('transfertime', 'portfolio'),
);
$logs = $DB->get_records('portfolio_log', array('userid' => $USER->id), 'time DESC', '*', ($page * $perpage), $perpage);
foreach ($logs as $log) {
if (!empty($log->caller_file)) {
portfolio_include_callback_file($log->caller_file);
} else if (!empty($log->caller_component)) {
portfolio_include_callback_file($log->caller_component);
} else { // Errrmahgerrrd - this should never happen. Skipping.
continue;
}
$class = $log->caller_class;
$pluginname = '';
try {
$plugin = portfolio_instance($log->portfolio);
$url = $plugin->resolve_static_continue_url($log->continueurl);
if ($url) {
$pluginname = '<a href="' . $url . '">' . $plugin->get('name') . '</a>';
} else {
$pluginname = $plugin->get('name');
}
} catch (portfolio_exception $e) { // May have been deleted.
$pluginname = get_string('unknownplugin', 'portfolio');
}
$table->data[] = array(
$pluginname,
'<a href="' . $log->returnurl . '">' . call_user_func(array($class, 'display_name')) . '</a>',
userdate($log->time),
);
}
echo $OUTPUT->heading(get_string('logsummary', 'portfolio'));
$pagingbar = new paging_bar($logcount, $page, $perpage, $CFG->wwwroot . '/user/portfoliologs.php?');
echo $OUTPUT->render($pagingbar);
echo html_writer::table($table);
echo $OUTPUT->render($pagingbar);
$somethingprinted = true;
}
if (!$somethingprinted) {
echo $OUTPUT->heading($strportfolios);
echo get_string('nologs', 'portfolio');
}
echo $OUTPUT->box_end();
echo $OUTPUT->footer();