. 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 * @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; } }