<?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'];
}
}