%PDF- %PDF-
Direktori : /home/vacivi36/ava/question/bank/customfields/classes/ |
Current File : /home/vacivi36/ava/question/bank/customfields/classes/plugin_feature.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; use core_question\local\bank\plugin_features_base; use core_question\local\bank\view; use qbank_customfields\customfield\question_handler; /** * Class plugin_feature is the entrypoint for the columns. * * @package qbank_customfields * @copyright 2021 Catalyst IT Australia Pty Ltd * @author Ghaly Marc-Alexandre <marc-alexandreghaly@catalyst-ca.net> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class plugin_feature extends plugin_features_base { /** * This method will return the array of objects to be rendered as a prt of question bank columns/actions. * * @param view $qbank * @return array */ public function get_question_columns(view $qbank): array { // We make a column for each custom field and load the data into it. $columns = []; // First get all the available question custom fields. $customfieldhandler = question_handler::create(); $fields = $customfieldhandler->get_fields(); $context = $qbank->get_most_specific_context(); // Iterate through the fields initialising a column for each. // We don't need to know the values that questions have at this stage. foreach ($fields as $field) { if ($customfieldhandler->can_view_type($field, $context)) { $customfieldcolumn = new custom_field_column($qbank, $field); $columns[] = $customfieldcolumn; } } return $columns; } }