mirror of
https://github.com/moodle/moodle.git
synced 2025-07-28 01:41:03 +02:00
Custom fields can now be added to question types. Site administrators can configure the custom fields and filed types available. Teachers and question creators can then use these fields for extra question metadata when creating questions. Question creators can control if the fields are displayed to students when they are taking a quiz or not. This features uses the core Moodle custom field API. Co-Authored-By: Matt Porritt <mattp@catalyst-au.net> Co-Authored-By: Safat Shahin <safatshahin@catalyst-au.net> Co-Authored-By: Marc-Alexandre Ghaly <marc-alexandreghaly@catalyst-ca.net>
60 lines
2.0 KiB
PHP
60 lines
2.0 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/>.
|
|
|
|
namespace qbank_customfields\output;
|
|
|
|
/**
|
|
* Class renderer.
|
|
*
|
|
* @package qbank_customfields
|
|
* @copyright 2021 Catalyst IT Australia Pty Ltd
|
|
* @author Matt Porritt <mattp@catalyst-ca.net>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
class renderer extends \plugin_renderer_base {
|
|
|
|
/**
|
|
* Render custom field data for table display.
|
|
*
|
|
* @param object $fielddata The field data to display.
|
|
* @return string The rendered HTML.
|
|
*/
|
|
public function render_for_table(object $fielddata): string {
|
|
$context = $fielddata->export_for_template($this);
|
|
return $this->render_from_template('qbank_customfields/table_display', $context);
|
|
}
|
|
|
|
/**
|
|
* Render custom filed data for table display.
|
|
*
|
|
* @param array $catfielddata The category and field data.
|
|
* @return string The rendered HTML.
|
|
*/
|
|
public function render_for_preview(array $catfielddata): string {
|
|
$context = ['categories' => []];
|
|
|
|
foreach ($catfielddata as $key => $value) {
|
|
$context['categories'][] = [
|
|
'catname' => $key,
|
|
'fields' => $value
|
|
];
|
|
|
|
}
|
|
|
|
return $this->render_from_template('qbank_customfields/preview_display', $context);
|
|
}
|
|
}
|