%PDF- %PDF-
Direktori : /home/vacivi36/ava/question/classes/local/bank/ |
Current File : /home/vacivi36/ava/question/classes/local/bank/edit_menu_column.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/>. /** * 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; /** * 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 * 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; $menu = new \action_menu(); $menu->set_menu_trigger(get_string('edit')); foreach ($this->actions as $actioncolumn) { $action = $actioncolumn->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. */ public function get_actions(): array { return $this->actions; } public function get_extra_classes(): array { return ['pr-3']; } }