Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.2.x will end 22 April 2024 (12 months).
  • Bug fixes for security issues in 4.2.x will end 7 October 2024 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.1.x is supported too.
<?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/>.

/**
 * A question bank column which gathers together all the actions into a menu.
 *
 * @package   core_question
 * @copyright 2019 The Open University
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace core_question\local\bank;

> use \core\plugininfo\qbank; /** >
* A question bank column which gathers together all the actions into a menu. * * This question bank column, if added to the question bank, will * replace all of the other columns which implement the
< * {@see menuable_action} interface and replace them with a single
> * {@see menu_action_column_base} interface and replace them with a single
* column containing an Edit menu. * * @copyright 2019 The Open University * @author 2021 Safat Shahin <safatshahin@catalyst-au.net> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class edit_menu_column extends column_base {
< /** < * @var menuable_action[] < */ < protected $actions; < < /** < * Set up the list of actions that should be shown in the menu. < * < * This takes a list of column object (the list from a question < * bank view). It extracts all the ones that should go in the menu < * and stores them for later use. Then it returns the remaining columns. < * < * @param column_base[] $allcolumns a set of columns. < * @return column_base[] the non-action columns from the set. < */ < public function claim_menuable_columns($allcolumns): array { < $remainingcolumns = []; < foreach ($allcolumns as $key => $column) { < if ($column instanceof menuable_action) { < $this->actions[$key] = $column; < } else { < $remainingcolumns[$key] = $column; < } < } < return $remainingcolumns; < } <
public function get_title() { return get_string('actions'); } public function get_name(): string { return 'editmenu'; } protected function display_content($question, $rowclasses): void { global $OUTPUT;
> $actions = $this->qbank->get_question_actions();
$menu = new \action_menu(); $menu->set_menu_trigger(get_string('edit'));
< foreach ($this->actions as $actioncolumn) { < $action = $actioncolumn->get_action_menu_link($question);
> foreach ($actions as $action) { > $action = $action->get_action_menu_link($question);
if ($action) { $menu->add($action); } } $qtypeactions = \question_bank::get_qtype($question->qtype, false) ->get_extra_question_bank_actions($question); foreach ($qtypeactions as $action) { $menu->add($action); } echo $OUTPUT->render($menu); } public function get_required_fields():array { return ['q.qtype']; } /** * Get menuable actions. *
< * @return menuable_action Menuable actions.
> * @return menu_action_column_base Menuable actions.
*/ public function get_actions(): array { return $this->actions; } public function get_extra_classes(): array { return ['pr-3']; } }